2016-09-20 09:19:45 +02:00
|
|
|
|
|
|
|
module.exports = function(RED) {
|
|
|
|
"use strict";
|
|
|
|
var fs = require('fs');
|
2020-12-02 00:43:48 +01:00
|
|
|
var allOK = false;
|
|
|
|
var mcpadc;
|
2016-09-20 09:19:45 +02:00
|
|
|
// unlikely if not on a Pi
|
2016-11-02 11:02:07 +01:00
|
|
|
try {
|
|
|
|
var cpuinfo = fs.readFileSync("/proc/cpuinfo").toString();
|
2020-12-02 00:43:48 +01:00
|
|
|
if (cpuinfo.indexOf(": BCM") === -1) {
|
|
|
|
RED.log.warn("Info : mcp3xxx : Not running on a Pi - Ignoring node");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
mcpadc = require('mcp-spi-adc');
|
|
|
|
allOK = true;
|
|
|
|
}
|
2017-01-29 18:45:44 +01:00
|
|
|
}
|
|
|
|
catch(err) {
|
2020-12-02 00:43:48 +01:00
|
|
|
RED.log.warn("Info : mcp3xxx : Not running on a Pi - Ignoring node");
|
2016-11-02 11:02:07 +01:00
|
|
|
}
|
2016-09-20 09:19:45 +02:00
|
|
|
|
2018-01-13 17:42:22 +01:00
|
|
|
var mcp3xxx = [];
|
2016-09-20 09:19:45 +02:00
|
|
|
|
|
|
|
function PiMcpNode(n) {
|
|
|
|
RED.nodes.createNode(this,n);
|
|
|
|
this.pin = n.pin || 0;
|
|
|
|
this.interval = n.interval || 1000;
|
2016-11-06 21:26:19 +01:00
|
|
|
this.dnum = parseInt(n.dnum || 0);
|
2018-09-21 14:53:08 +02:00
|
|
|
this.bus = parseInt(n.bus || 0);
|
2018-01-13 17:42:22 +01:00
|
|
|
this.dev = n.dev || "3008";
|
2016-09-20 09:19:45 +02:00
|
|
|
var node = this;
|
2018-01-13 17:42:22 +01:00
|
|
|
var cb = function (err) { if (err) { node.error("Error: "+err); } };
|
2018-09-21 14:53:08 +02:00
|
|
|
var opt = { speedHz:20000, deviceNumber:node.dnum, busNumber:node.bus };
|
2018-01-13 17:42:22 +01:00
|
|
|
var chans = parseInt(this.dev.substr(3));
|
2016-09-20 09:19:45 +02:00
|
|
|
|
2020-12-02 00:43:48 +01:00
|
|
|
if (allOK === true) {
|
|
|
|
try {
|
|
|
|
fs.statSync("/dev/spidev"+node.bus+"."+node.dnum);
|
|
|
|
if (mcp3xxx.length === 0) {
|
|
|
|
for (var i=0; i<chans; i++) {
|
|
|
|
if (node.dev === "3002") { mcp3xxx.push(mcpadc.openMcp3002(i, opt, cb)); }
|
|
|
|
if (node.dev === "3004") { mcp3xxx.push(mcpadc.openMcp3004(i, opt, cb)); }
|
|
|
|
if (node.dev === "3008") { mcp3xxx.push(mcpadc.openMcp3008(i, opt, cb)); }
|
|
|
|
if (node.dev === "3202") { mcp3xxx.push(mcpadc.openMcp3202(i, opt, cb)); }
|
|
|
|
if (node.dev === "3204") { mcp3xxx.push(mcpadc.openMcp3204(i, opt, cb)); }
|
|
|
|
if (node.dev === "3208") { mcp3xxx.push(mcpadc.openMcp3208(i, opt, cb)); }
|
|
|
|
if (node.dev === "3304") { mcp3xxx.push(mcpadc.openMcp3304(i, opt, cb)); }
|
|
|
|
}
|
2016-09-20 09:19:45 +02:00
|
|
|
}
|
2020-12-02 00:43:48 +01:00
|
|
|
node.on("input", function(msg) {
|
|
|
|
var pin = null;
|
|
|
|
if (node.pin === "M") {
|
|
|
|
var pay = parseInt(msg.payload.toString());
|
|
|
|
if ((pay >= 0) && (pay < chans)) { pin = pay; }
|
|
|
|
else { node.warn("Payload needs to select channel 0 to "+(chans-1)); }
|
|
|
|
}
|
|
|
|
else { pin = parseInt(node.pin); }
|
|
|
|
if (pin !== null) {
|
|
|
|
mcp3xxx[pin].read(function (err, reading) {
|
|
|
|
if (err) { node.warn("Read error: "+err); }
|
|
|
|
else { node.send({payload:reading.rawValue, topic:"adc/"+pin}); }
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
2016-09-20 09:19:45 +02:00
|
|
|
}
|
2020-12-02 00:43:48 +01:00
|
|
|
catch(err) {
|
|
|
|
node.error("Error : Can't find SPI device - is SPI enabled in raspi-config ?");
|
|
|
|
}
|
|
|
|
|
|
|
|
node.on("close", function(done) {
|
|
|
|
if (mcp3xxx.length !== 0) {
|
|
|
|
var j=0;
|
|
|
|
for (var i=0; i<chans; i++) {
|
|
|
|
mcp3xxx[i].close(function() { j += 1; if (j === chans) {done()} });
|
|
|
|
}
|
|
|
|
mcp3xxx = [];
|
2016-09-20 09:19:45 +02:00
|
|
|
}
|
2020-12-02 00:43:48 +01:00
|
|
|
else { done(); }
|
2016-09-20 09:19:45 +02:00
|
|
|
});
|
|
|
|
}
|
2020-12-02 00:43:48 +01:00
|
|
|
else {
|
|
|
|
node.status({text:"node inactive."})
|
2016-09-20 09:19:45 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
RED.nodes.registerType("pimcp3008",PiMcpNode);
|
|
|
|
}
|