mirror of
https://github.com/eclipse/upm.git
synced 2025-03-15 04:57:30 +03:00
AD8232: Make some changes in cpp interface
Signed-off-by: Adelin Dobre <adelin.dobre@rinftech.com>
This commit is contained in:
parent
4f661d6bbf
commit
93622b0323
@ -31,74 +31,60 @@
|
||||
using namespace upm;
|
||||
using namespace std;
|
||||
|
||||
static bool operator!(mraa::MraaIo &mraaIo)
|
||||
|
||||
AD8232::AD8232(int loPlus, int loMinus, int output, float aref) :
|
||||
m_gpioLOPlus(loPlus), m_gpioLOMinus(loMinus), m_aioOUT(output)
|
||||
{
|
||||
return mraaIo.getMraaDescriptors() == NULL;
|
||||
}
|
||||
|
||||
AD8232::AD8232(int loPlus, int loMinus, int output, float aref) {
|
||||
m_gpioLOPlus = new mraa::Gpio(loPlus);
|
||||
m_gpioLOMinus = new mraa::Gpio(loMinus);
|
||||
m_aioOUT = new mraa::Aio(output);
|
||||
|
||||
m_gpioLOPlus->dir(mraa::DIR_IN);
|
||||
m_gpioLOMinus->dir(mraa::DIR_IN);
|
||||
m_gpioLOPlus.dir(mraa::DIR_IN);
|
||||
m_gpioLOMinus.dir(mraa::DIR_IN);
|
||||
|
||||
m_aref = aref;
|
||||
m_ares = (1 << m_aioOUT->getBit());
|
||||
m_ares = (1 << m_aioOUT.getBit());
|
||||
}
|
||||
|
||||
AD8232::AD8232(std::string initStr) : mraaIo(initStr) {
|
||||
if(!mraaIo.gpios.empty()) {
|
||||
if(mraaIo.gpios.size() == 2) {
|
||||
m_gpioLOPlus = &mraaIo.gpios[0];
|
||||
m_gpioLOMinus = &mraaIo.gpios[1];
|
||||
}
|
||||
else {
|
||||
throw std::invalid_argument(std::string(__FUNCTION__) +
|
||||
": mraa_gpio_init() must initialize two pins");
|
||||
}
|
||||
}
|
||||
else {
|
||||
throw std::invalid_argument(std::string(__FUNCTION__) +
|
||||
": mraa_gpio_init() failed, invalid pin?");
|
||||
}
|
||||
|
||||
if(!mraaIo.aios.empty()) {
|
||||
m_aioOUT = &mraaIo.aios[0];
|
||||
}
|
||||
else {
|
||||
throw std::invalid_argument(std::string(__FUNCTION__) +
|
||||
": mraa_aio_init() failed, invalid pin?");
|
||||
}
|
||||
|
||||
AD8232::AD8232(std::string initStr) :
|
||||
m_gpioLOPlus(nullptr), m_gpioLOMinus(nullptr), m_aioOUT(nullptr), mraaIo(initStr) {
|
||||
|
||||
mraa_io_descriptor* descs = mraaIo.getMraaDescriptors();
|
||||
std::vector<std::string> upmTokens;
|
||||
|
||||
|
||||
if(!mraaIo.getLeftoverStr().empty()) {
|
||||
upmTokens = UpmStringParser::parse(mraaIo.getLeftoverStr());
|
||||
}
|
||||
|
||||
if(!descs->gpios) {
|
||||
throw std::invalid_argument(std::string(__FUNCTION__) +
|
||||
": mraa_gpio_init() must initialize two pins");
|
||||
} else {
|
||||
if(descs->gpios[0])
|
||||
m_gpioLOPlus = descs->gpios[0];
|
||||
if(descs->gpios[1])
|
||||
m_gpioLOMinus = descs->gpios[1];
|
||||
}
|
||||
|
||||
if(!descs->aios){
|
||||
throw std::invalid_argument(std::string(__FUNCTION__) +
|
||||
": mraa_aio_init() failed, invalid pin?");
|
||||
} else {
|
||||
m_aioOUT = descs->aios[0];
|
||||
}
|
||||
|
||||
for (std::string tok : upmTokens) {
|
||||
if(tok.substr(0, 5) == "volt:") {
|
||||
if(tok.substr(0, 5) == "aref:") {
|
||||
m_aref = std::stof(tok.substr(5));
|
||||
}
|
||||
}
|
||||
m_ares = (1 << m_aioOUT->getBit());
|
||||
m_ares = (1 << m_aioOUT.getBit());
|
||||
}
|
||||
|
||||
AD8232::~AD8232()
|
||||
{
|
||||
if(!mraaIo) {
|
||||
delete m_gpioLOPlus;
|
||||
delete m_gpioLOMinus;
|
||||
delete m_aioOUT;
|
||||
}
|
||||
}
|
||||
|
||||
int AD8232::value()
|
||||
{
|
||||
if (m_gpioLOPlus->read() || m_gpioLOMinus->read())
|
||||
if (m_gpioLOPlus.read() || m_gpioLOMinus.read())
|
||||
return 0;
|
||||
else
|
||||
return m_aioOUT->read();
|
||||
return m_aioOUT.read();
|
||||
}
|
||||
|
@ -105,10 +105,10 @@ namespace upm {
|
||||
int value();
|
||||
|
||||
private:
|
||||
mraa::Gpio m_gpioLOPlus;
|
||||
mraa::Gpio m_gpioLOMinus;
|
||||
mraa::Aio m_aioOUT;
|
||||
mraa::MraaIo mraaIo;
|
||||
mraa::Gpio *m_gpioLOPlus = NULL;
|
||||
mraa::Gpio *m_gpioLOMinus = NULL;
|
||||
mraa::Aio *m_aioOUT = NULL;
|
||||
|
||||
float m_aref;
|
||||
int m_ares;
|
||||
|
Loading…
x
Reference in New Issue
Block a user