2020-02-10 15:21:58 +01:00
|
|
|
|
|
2013-11-01 23:48:39 +01:00
|
|
|
|
// STL includes
|
|
|
|
|
#include <cstring>
|
|
|
|
|
#include <cstdio>
|
|
|
|
|
#include <iostream>
|
2016-06-25 14:44:52 +02:00
|
|
|
|
#include <cerrno>
|
2013-11-01 23:48:39 +01:00
|
|
|
|
|
|
|
|
|
// Linux includes
|
|
|
|
|
#include <fcntl.h>
|
2020-02-10 15:21:58 +01:00
|
|
|
|
#include <unistd.h>
|
2013-11-01 23:48:39 +01:00
|
|
|
|
#include <sys/ioctl.h>
|
|
|
|
|
|
|
|
|
|
// Local Hyperion includes
|
2016-08-28 07:12:48 +02:00
|
|
|
|
#include "ProviderSpi.h"
|
2016-06-25 14:44:52 +02:00
|
|
|
|
#include <utils/Logger.h>
|
2013-11-01 23:48:39 +01:00
|
|
|
|
|
|
|
|
|
|
2016-10-08 08:14:36 +02:00
|
|
|
|
ProviderSpi::ProviderSpi()
|
2016-08-23 20:07:12 +02:00
|
|
|
|
: LedDevice()
|
2016-10-08 08:14:36 +02:00
|
|
|
|
, _deviceName("/dev/spidev0.0")
|
|
|
|
|
, _baudRate_Hz(1000000)
|
2016-08-14 10:46:44 +02:00
|
|
|
|
, _fid(-1)
|
2016-10-08 08:14:36 +02:00
|
|
|
|
, _spiMode(SPI_MODE_0)
|
|
|
|
|
, _spiDataInvert(false)
|
2013-11-01 23:48:39 +01:00
|
|
|
|
{
|
2016-08-14 10:46:44 +02:00
|
|
|
|
memset(&_spi, 0, sizeof(_spi));
|
2017-04-09 22:28:32 +02:00
|
|
|
|
_latchTime_ms = 1;
|
2013-11-01 23:48:39 +01:00
|
|
|
|
}
|
|
|
|
|
|
2016-08-28 07:12:48 +02:00
|
|
|
|
ProviderSpi::~ProviderSpi()
|
2013-11-01 23:48:39 +01:00
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2016-10-13 21:59:58 +02:00
|
|
|
|
bool ProviderSpi::init(const QJsonObject &deviceConfig)
|
2016-08-23 20:07:12 +02:00
|
|
|
|
{
|
2020-02-10 15:21:58 +01:00
|
|
|
|
bool isInitOK = LedDevice::init(deviceConfig);
|
2016-12-02 12:07:24 +01:00
|
|
|
|
|
2017-03-04 22:17:42 +01:00
|
|
|
|
_deviceName = deviceConfig["output"].toString(_deviceName);
|
2016-10-13 21:59:58 +02:00
|
|
|
|
_baudRate_Hz = deviceConfig["rate"].toInt(_baudRate_Hz);
|
|
|
|
|
_spiMode = deviceConfig["spimode"].toInt(_spiMode);
|
|
|
|
|
_spiDataInvert = deviceConfig["invert"].toBool(_spiDataInvert);
|
2016-12-02 12:07:24 +01:00
|
|
|
|
|
2020-02-10 15:21:58 +01:00
|
|
|
|
return isInitOK;
|
2016-08-23 20:07:12 +02:00
|
|
|
|
}
|
|
|
|
|
|
2016-08-28 07:12:48 +02:00
|
|
|
|
int ProviderSpi::open()
|
2013-11-01 23:48:39 +01:00
|
|
|
|
{
|
2020-02-10 15:21:58 +01:00
|
|
|
|
int retval = -1;
|
|
|
|
|
QString errortext;
|
|
|
|
|
_deviceReady = false;
|
2016-09-04 14:28:06 +02:00
|
|
|
|
|
2020-02-10 15:21:58 +01:00
|
|
|
|
if ( init(_devConfig) )
|
|
|
|
|
{
|
2013-11-01 23:48:39 +01:00
|
|
|
|
|
fix: Rewrite-/LatchTime LedDevice definitions (#785) (#799)
* Fix Rewrite/Latch Time
* dependencies can now be specified in the schema
Signed-off-by: Paulchen-Panther <Paulchen-Panter@protonmail.com>
* dependencies can now be specified in the schema
Signed-off-by: Paulchen-Panther <Paulchen-Panter@protonmail.com>
* correct default config
Signed-off-by: Paulchen-Panther <Paulchen-Panter@protonmail.com>
* dependencies part 2
Signed-off-by: Paulchen-Panther <Paulchen-Panter@protonmail.com>
* Update README.md
* build: Update Windows to Qt5.15 (#798)
* Update compile howto
- to qt5.15
- minimal install overhead
- sync with vscode and cmake
* Update docs with more input
gh actions windows: Qt5.15 and msvc2019
* fix: Azure build
* feat: Add Trapezoid to LED Layout (#791)
* Update schema-ledConfig.json
extend schema with corner points (vertcal and horizontal values in percent)
* Update conf_leds.html
input fields for corner points
* Update content_leds.js
add corner values and calculation of led rows
* Update de.json
german title for corners
* CHanges 26.12.2019 Correction and PowerOff add
* GrabberFix PiCam
* VType as QString
* Unused variable deletet
* Missing new paramneters for GrabberFix
* Error json
* JSon error by user
* Crosscompile SutnikElf frok
* Warning unused variable
* Revert "Crosscompile SutnikElf frok"
This reverts commit 443fe8009021f15b617292868c778499c13282a7.
* Fixing a linting error
* Adding Grabber Override Names
* Adding more Grabber Fix translations
* Missed one
* remove V4L2 Grabber Fix and Power Button from Dashboard
Signed-off-by: Paulchen-Panther <Paulchen-Panter@protonmail.com>
* Setting some limits to the trapezoid
Co-authored-by: SputnikElf <58911932+SputnikElf@users.noreply.github.com>
Co-authored-by: SputnikElf <sputnikelf@gmx.de>
Co-authored-by: Paulchen-Panther <Paulchen-Panter@protonmail.com>
* add Hue EntertainmentAPI + Forwarder & other Fixes (#592)
* whitespaces + typo fixes
* JS / LGTM fixes
* SSDP Handler crash fix
* MessageForwarder handlePriorityChanges Slave fixes
* use aboutToQuit Signal
* complete rewriten Hue Entertainment API structure
combined Philips Hue and Entertainment API
with new MbedTLS based SSL UDP Provider
* add required cross-compile submodules
* logical rebuild fn: initLeds, setLights + new logs
-more detailed checks and error handling inside iniLeds and setLights
- logical script procedure before ProviderUdpSSL init
- first steps for multiple ProviderUdpSSL usage
- better fallback support to old RestAPI, if entertainment api is not supported
- just 4 u LordGrey: new log fn for cosmetic config outputs ;)
* add OSX CompileHowTo - undo from CrossCompileHowTo
* whitespace fixes
* lightID toString fix
* fix unsigned int E-API + debug output
* bugfixes, reworked black signal detection, wizard:
- change device config field light-ids from int to string -> real unsigned int fix
- add signal detection brightness minimum threshold value
0.0 for 0% brightness - 1.0 for 100% brightness to count for blacklight signal detection
reason: input may not 100% black, like mine - i have a deep dark gray input signal
-> my threshold value is set to 0.005 for 0.5% minimum brightness = 1 (from max 255) to count as black
- wizard optimations, with fallback without entertainment support (beta state)
- whitespace fixes
* cleanup + minor fixes
* change fixed Hue UPD SSL config to _devConfig paras
* Hotfix SSL Connection, new light models, wizard:
- Fix UPD SSL Connection failed Problems
- add new supported gamut C light models: LCG002, LCA001, LCA002, LCA003
- wizard: extend fallback support to classic mode + hints
* whitespace, typo fix
* uncheck useEntertainmentAPI, if noAPISupport detected + hint
* coredump fix -> add _blackLightsTimer nullptr init
* code cleanup / remove old debugs + whitespacefixes
* add gamut C LCP001, LCP002
* SSL UDP config made more flexible + remove qDebug
-> switch to hyerion.ng _log
-> replace logCommand with verbose
-> code cleanups etc...
* extended mbedtls debugging infos
* add adjustable ssl timeout settings
* error handling
* streamdebugger bugfixes
* UPDSSL psk / psk_identity bugfixes! + hue wizard fn typo fix +
- verbose option available without dependencies
- whitespace fixes
* Philips Hue Assistant now recognizes non-original bridges better...
+ Added note if no clientkey is set when using the entertainment API
+ User creation (+ clientkey) for non-original bridges can now also be used
+ Minor changes and bug fixes
* CMAKE mbedTLS detection
* minor bug fixes + code cleanups
* FindMbedTLS.cmake remove Path-Hints + wizard.js: ajax timeout handling
Test - content_grabber.js: run relevant code only, if V4L2_AVAIL is true:
conf_grabber don't displays other devices, if V4L2 is not available
* compile mbedtls via cmake as static lib
* remove libmbedtls-dev from compileHowto / scripts
* Fix Windows build
* Fix windows build (part 2)
* removed unnecessary osx x11 include directory path
* QTimer Shutdown bugfix
* cmake win32 fix + minor bugfixes
* cmake debug msg used mbedtls libs
* Bugfix: noSignalDetection wasn't switchedOn again
if no signal was previously detected
* Some code fixes based on alerts from lgtm.com
Co-authored-by: Paulchen Panther <16664240+Paulchen-Panther@users.noreply.github.com>
* Update devices allowing rewriteTime
* Fix typo
* Add missing "general_btn_saverestart" text to en-file
Co-authored-by: Paulchen-Panther <Paulchen-Panter@protonmail.com>
Co-authored-by: Paulchen Panther <16664240+Paulchen-Panther@users.noreply.github.com>
Co-authored-by: brindosch <edeltraud70@gmx.de>
Co-authored-by: Ben Williams <desertblade@gmail.com>
Co-authored-by: SputnikElf <58911932+SputnikElf@users.noreply.github.com>
Co-authored-by: SputnikElf <sputnikelf@gmx.de>
Co-authored-by: SJunkies <41368976+SJunkies@users.noreply.github.com>
2020-05-26 22:28:36 +02:00
|
|
|
|
Debug(_log, "_baudRate_Hz [%d], _latchTime_ms [%d]", _baudRate_Hz, _latchTime_ms);
|
|
|
|
|
Debug(_log, "_spiDataInvert [%d], _spiMode [%d]", _spiDataInvert, _spiMode);
|
2013-11-01 23:48:39 +01:00
|
|
|
|
|
2020-02-10 15:21:58 +01:00
|
|
|
|
const int bitsPerWord = 8;
|
2013-11-01 23:48:39 +01:00
|
|
|
|
|
2020-02-10 15:21:58 +01:00
|
|
|
|
_fid = ::open(QSTRING_CSTR(_deviceName), O_RDWR);
|
2013-11-01 23:48:39 +01:00
|
|
|
|
|
2020-02-10 15:21:58 +01:00
|
|
|
|
if (_fid < 0)
|
|
|
|
|
{
|
|
|
|
|
errortext = QString ("Failed to open device (%1). Error message: %2").arg(_deviceName, strerror(errno));
|
|
|
|
|
retval = -1;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
if (ioctl(_fid, SPI_IOC_WR_MODE, &_spiMode) == -1 || ioctl(_fid, SPI_IOC_RD_MODE, &_spiMode) == -1)
|
|
|
|
|
{
|
|
|
|
|
retval = -2;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
if (ioctl(_fid, SPI_IOC_WR_BITS_PER_WORD, &bitsPerWord) == -1 || ioctl(_fid, SPI_IOC_RD_BITS_PER_WORD, &bitsPerWord) == -1)
|
|
|
|
|
{
|
|
|
|
|
retval = -4;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
if (ioctl(_fid, SPI_IOC_WR_MAX_SPEED_HZ, &_baudRate_Hz) == -1 || ioctl(_fid, SPI_IOC_RD_MAX_SPEED_HZ, &_baudRate_Hz) == -1)
|
|
|
|
|
{
|
|
|
|
|
retval = -6;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
// Everything OK -> enable device
|
|
|
|
|
_deviceReady = true;
|
|
|
|
|
setEnable(true);
|
|
|
|
|
retval = 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if ( retval < 0 )
|
|
|
|
|
{
|
2020-03-26 18:49:44 +01:00
|
|
|
|
errortext = QString ("Failed to open device (%1). Error Code: %2").arg(_deviceName).arg(retval);
|
2020-02-10 15:21:58 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ( retval < 0 )
|
|
|
|
|
{
|
|
|
|
|
this->setInError( errortext );
|
|
|
|
|
}
|
2013-11-01 23:48:39 +01:00
|
|
|
|
}
|
|
|
|
|
|
2020-02-10 15:21:58 +01:00
|
|
|
|
return retval;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void ProviderSpi::close()
|
|
|
|
|
{
|
|
|
|
|
LedDevice::close();
|
|
|
|
|
|
|
|
|
|
// Device specific closing activites
|
|
|
|
|
if ( _fid > -1 )
|
2013-11-01 23:48:39 +01:00
|
|
|
|
{
|
2020-02-10 15:21:58 +01:00
|
|
|
|
if ( ::close(_fid) != 0 )
|
|
|
|
|
{
|
|
|
|
|
Error( _log, "Failed to close device (%s). Error message: %s", QSTRING_CSTR(_deviceName), strerror(errno) );
|
|
|
|
|
}
|
2013-11-01 23:48:39 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
2013-11-02 06:51:41 +01:00
|
|
|
|
|
2016-08-28 07:12:48 +02:00
|
|
|
|
int ProviderSpi::writeBytes(const unsigned size, const uint8_t * data)
|
2013-11-02 06:51:41 +01:00
|
|
|
|
{
|
2016-08-14 10:46:44 +02:00
|
|
|
|
if (_fid < 0)
|
2013-11-02 06:51:41 +01:00
|
|
|
|
{
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
|
2016-08-14 10:46:44 +02:00
|
|
|
|
_spi.tx_buf = __u64(data);
|
|
|
|
|
_spi.len = __u32(size);
|
2013-11-02 06:51:41 +01:00
|
|
|
|
|
2016-08-14 10:46:44 +02:00
|
|
|
|
if (_spiDataInvert)
|
|
|
|
|
{
|
2016-08-13 19:54:08 +02:00
|
|
|
|
uint8_t * newdata = (uint8_t *)malloc(size);
|
|
|
|
|
for (unsigned i = 0; i<size; i++) {
|
|
|
|
|
newdata[i] = data[i] ^ 0xff;
|
|
|
|
|
}
|
2016-08-14 10:46:44 +02:00
|
|
|
|
_spi.tx_buf = __u64(newdata);
|
2016-08-13 19:54:08 +02:00
|
|
|
|
}
|
|
|
|
|
|
2016-08-14 10:46:44 +02:00
|
|
|
|
int retVal = ioctl(_fid, SPI_IOC_MESSAGE(1), &_spi);
|
2016-08-31 09:51:50 +02:00
|
|
|
|
ErrorIf((retVal < 0), _log, "SPI failed to write. errno: %d, %s", errno, strerror(errno) );
|
2013-11-02 06:51:41 +01:00
|
|
|
|
|
|
|
|
|
return retVal;
|
|
|
|
|
}
|