led device cleanup, bug fix and schemas (#304)

* sk6812SPI was buggy
cleaned up code - make sk6812spi and ws2812spi more consistent

* led device schema updates
This commit is contained in:
penfold42 2016-12-02 02:16:59 +11:00 committed by redPanther
parent 080059cbf5
commit 1670ec58a7
8 changed files with 70 additions and 22 deletions

View File

@ -20,7 +20,7 @@
<file alias="schema-rawhid">schemas/schema-rawhid.json</file> <file alias="schema-rawhid">schemas/schema-rawhid.json</file>
<file alias="schema-sedu">schemas/schema-sedu.json</file> <file alias="schema-sedu">schemas/schema-sedu.json</file>
<file alias="schema-dmx">schemas/schema-dmx.json</file> <file alias="schema-dmx">schemas/schema-dmx.json</file>
<file alias="schema-sk6812rgbw-spi">schemas/schema-sk6812rgbw-spi.json</file> <file alias="schema-sk6812spi">schemas/schema-sk6812spi.json</file>
<file alias="schema-tinkerforge">schemas/schema-tinkerforge.json</file> <file alias="schema-tinkerforge">schemas/schema-tinkerforge.json</file>
<file alias="schema-tpm2net">schemas/schema-tpm2net.json</file> <file alias="schema-tpm2net">schemas/schema-tpm2net.json</file>
<file alias="schema-tpm2.json">schemas/schema-tpm2.json</file> <file alias="schema-tpm2.json">schemas/schema-tpm2.json</file>

View File

@ -3,6 +3,7 @@
LedDeviceSk6812SPI::LedDeviceSk6812SPI(const QJsonObject &deviceConfig) LedDeviceSk6812SPI::LedDeviceSk6812SPI(const QJsonObject &deviceConfig)
: ProviderSpi() : ProviderSpi()
, _whiteAlgorithm(RGBW::INVALID) , _whiteAlgorithm(RGBW::INVALID)
, SPI_BYTES_PER_COLOUR(4)
, bitpair_to_byte { , bitpair_to_byte {
0b10001000, 0b10001000,
0b10001100, 0b10001100,
@ -35,8 +36,8 @@ bool LedDeviceSk6812SPI::init(const QJsonObject &deviceConfig)
{ {
return false; return false;
} }
WarningIf(( _baudRate_Hz < 2050000 || _baudRate_Hz > 4000000 ), _log, "SPI rate %d outside recommended range (2050000 -> 4000000)", _baudRate_Hz);
const int SPI_BYTES_PER_COLOUR = 4;
const int SPI_FRAME_END_LATCH_BYTES = 3; const int SPI_FRAME_END_LATCH_BYTES = 3;
_ledBuffer.resize(_ledRGBWCount * SPI_BYTES_PER_COLOUR + SPI_FRAME_END_LATCH_BYTES, 0x00); _ledBuffer.resize(_ledRGBWCount * SPI_BYTES_PER_COLOUR + SPI_FRAME_END_LATCH_BYTES, 0x00);
@ -46,7 +47,8 @@ bool LedDeviceSk6812SPI::init(const QJsonObject &deviceConfig)
int LedDeviceSk6812SPI::write(const std::vector<ColorRgb> &ledValues) int LedDeviceSk6812SPI::write(const std::vector<ColorRgb> &ledValues)
{ {
unsigned spi_ptr = 0; unsigned spi_ptr = 0;
static const int SPI_BYTES_PER_LED = 4; const int SPI_BYTES_PER_LED = sizeof(ColorRgbw) * SPI_BYTES_PER_COLOUR;
for (const ColorRgb& color : ledValues) for (const ColorRgb& color : ledValues)
{ {
@ -57,7 +59,8 @@ int LedDeviceSk6812SPI::write(const std::vector<ColorRgb> &ledValues)
((uint32_t)_temp_rgbw.blue << 8) + ((uint32_t)_temp_rgbw.blue << 8) +
_temp_rgbw.white; _temp_rgbw.white;
for (int j=SPI_BYTES_PER_LED - 1; j>=0; j--) { for (int j=SPI_BYTES_PER_LED - 1; j>=0; j--)
{
_ledBuffer[spi_ptr+j] = bitpair_to_byte[ colorBits & 0x3 ]; _ledBuffer[spi_ptr+j] = bitpair_to_byte[ colorBits & 0x3 ];
colorBits >>= 2; colorBits >>= 2;
} }

View File

@ -37,6 +37,8 @@ private:
RGBW::WhiteAlgorithm _whiteAlgorithm; RGBW::WhiteAlgorithm _whiteAlgorithm;
const int SPI_BYTES_PER_COLOUR;
uint8_t bitpair_to_byte[4]; uint8_t bitpair_to_byte[4];
ColorRgbw _temp_rgbw; ColorRgbw _temp_rgbw;

View File

@ -2,6 +2,7 @@
LedDeviceWs2812SPI::LedDeviceWs2812SPI(const QJsonObject &deviceConfig) LedDeviceWs2812SPI::LedDeviceWs2812SPI(const QJsonObject &deviceConfig)
: ProviderSpi() : ProviderSpi()
, SPI_BYTES_PER_COLOUR(4)
, bitpair_to_byte { , bitpair_to_byte {
0b10001000, 0b10001000,
0b10001100, 0b10001100,
@ -20,29 +21,28 @@ LedDevice* LedDeviceWs2812SPI::construct(const QJsonObject &deviceConfig)
bool LedDeviceWs2812SPI::init(const QJsonObject &deviceConfig) bool LedDeviceWs2812SPI::init(const QJsonObject &deviceConfig)
{ {
_baudRate_Hz = 3000000; _baudRate_Hz = 3000000;
ProviderSpi::init(deviceConfig); if ( !ProviderSpi::init(deviceConfig) )
{
return false;
}
WarningIf(( _baudRate_Hz < 2050000 || _baudRate_Hz > 4000000 ), _log, "SPI rate %d outside recommended range (2050000 -> 4000000)", _baudRate_Hz); WarningIf(( _baudRate_Hz < 2050000 || _baudRate_Hz > 4000000 ), _log, "SPI rate %d outside recommended range (2050000 -> 4000000)", _baudRate_Hz);
const int SPI_FRAME_END_LATCH_BYTES = 3;
_ledBuffer.resize(_ledRGBCount * SPI_BYTES_PER_COLOUR + SPI_FRAME_END_LATCH_BYTES, 0x00);
return true; return true;
} }
int LedDeviceWs2812SPI::write(const std::vector<ColorRgb> &ledValues) int LedDeviceWs2812SPI::write(const std::vector<ColorRgb> &ledValues)
{ {
// 3 colours, 4 spi bytes per colour + 3 frame end latch bytes
const int SPI_BYTES_PER_LED = 3 * 4;
unsigned spi_size = _ledCount * SPI_BYTES_PER_LED + 3;
if(_ledBuffer.size() != spi_size)
{
_ledBuffer.resize(spi_size, 0x00);
}
unsigned spi_ptr = 0; unsigned spi_ptr = 0;
for (unsigned i=0; i<(unsigned)_ledCount; ++i) const int SPI_BYTES_PER_LED = sizeof(ColorRgb) * SPI_BYTES_PER_COLOUR;
for (const ColorRgb& color : ledValues)
{ {
uint32_t colorBits = ((unsigned int)ledValues[i].red << 16) uint32_t colorBits = ((unsigned int)color.red << 16)
| ((unsigned int)ledValues[i].green << 8) | ((unsigned int)color.green << 8)
| ledValues[i].blue; | color.blue;
for (int j=SPI_BYTES_PER_LED - 1; j>=0; j--) for (int j=SPI_BYTES_PER_LED - 1; j>=0; j--)
{ {
@ -51,9 +51,10 @@ int LedDeviceWs2812SPI::write(const std::vector<ColorRgb> &ledValues)
} }
spi_ptr += SPI_BYTES_PER_LED; spi_ptr += SPI_BYTES_PER_LED;
} }
_ledBuffer[spi_ptr++] = 0; _ledBuffer[spi_ptr++] = 0;
_ledBuffer[spi_ptr++] = 0; _ledBuffer[spi_ptr++] = 0;
_ledBuffer[spi_ptr++] = 0; _ledBuffer[spi_ptr++] = 0;
return writeBytes(spi_size, _ledBuffer.data()); return writeBytes(_ledBuffer.size(), _ledBuffer.data());
} }

View File

@ -35,5 +35,7 @@ private:
/// ///
virtual int write(const std::vector<ColorRgb> &ledValues); virtual int write(const std::vector<ColorRgb> &ledValues);
const int SPI_BYTES_PER_COLOUR;
uint8_t bitpair_to_byte[4]; uint8_t bitpair_to_byte[4];
}; };

View File

@ -11,7 +11,7 @@
"rate": { "rate": {
"type": "integer", "type": "integer",
"title":"Baudrate", "title":"Baudrate",
"default": 2666666, "default": 3000000,
"propertyOrder" : 2 "propertyOrder" : 2
}, },
"invert": { "invert": {
@ -20,6 +20,13 @@
"title":"Invert signal", "title":"Invert signal",
"default": false, "default": false,
"propertyOrder" : 3 "propertyOrder" : 3
},
"whiteAlgorithm": {
"type": "string",
"title":"White LED algorithm",
"enum" : ["subtract_minimum","sub_min_warm_adjust","white_off"],
"default": "subtract_minimum",
"propertyOrder" : 4
} }
}, },
"additionalProperties": true "additionalProperties": true

View File

@ -11,7 +11,7 @@
"rate": { "rate": {
"type": "integer", "type": "integer",
"title":"Baudrate", "title":"Baudrate",
"default": 1000000, "default": 3000000,
"propertyOrder" : 2 "propertyOrder" : 2
}, },
"invert": { "invert": {

View File

@ -2,6 +2,39 @@
"type":"object", "type":"object",
"required":true, "required":true,
"properties":{ "properties":{
"leds": {
"type": "integer",
"title":"maximum led count",
"default": 256,
"propertyOrder" : 1
},
"gpio": {
"type": "integer",
"title":"gpio number",
"default": 18,
"propertyOrder" : 2
},
"invert": {
"type": "boolean",
"format": "checkbox",
"title":"Invert signal",
"default": false,
"propertyOrder" : 3
},
"rgbw": {
"type": "boolean",
"format": "checkbox",
"title":"use rgbw protocol",
"default": false,
"propertyOrder" : 3
},
"whiteAlgorithm": {
"type": "string",
"title":"White LED algorithm",
"enum" : ["subtract_minimum","sub_min_warm_adjust","white_off"],
"default": "subtract_minimum",
"propertyOrder" : 4
}
}, },
"additionalProperties": true "additionalProperties": true
} }