A collection of Analog Devices drivers for the mbed platform
For additional information check out the mbed page of the Analog Devices wiki: https://wiki.analog.com/resources/tools-software/mbed-drivers-all
Diff: examples/drvdiag/driver_wrapper/CN0398_Diag.cpp
- Revision:
- 33:c3ec596a29c2
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/examples/drvdiag/driver_wrapper/CN0398_Diag.cpp Mon Nov 07 16:27:12 2016 +0200
@@ -0,0 +1,331 @@
+/**
+ * @file ad7124_diag.cpp
+ * @brief Source file for the AD7124 wrapper used by the driver diag
+ * @author Analog Devices Inc.
+ *
+ * For support please go to:
+ * Github: https://github.com/analogdevicesinc/mbed-adi
+ * Support: https://ez.analog.com/community/linux-device-drivers/microcontroller-no-os-drivers
+ * More: https://wiki.analog.com/resources/tools-software/mbed-drivers-all
+
+ ********************************************************************************
+ * Copyright 2016(c) Analog Devices, Inc.
+ *
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ * - Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * - Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in
+ * the documentation and/or other materials provided with the
+ * distribution.
+ * - Neither the name of Analog Devices, Inc. nor the names of its
+ * contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ * - The use of this software may or may not infringe the patent rights
+ * of one or more patent holders. This license does not release you
+ * from the requirement that you obtain separate licenses from these
+ * patent holders to use this software.
+ * - Use of the software either in source or binary form, must be run
+ * on or directly connected to an Analog Devices Inc. component.
+ *
+ * THIS SOFTWARE IS PROVIDED BY ANALOG DEVICES "AS IS" AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, NON-INFRINGEMENT,
+ * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL ANALOG DEVICES BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+ * LIMITED TO, INTELLECTUAL PROPERTY RIGHTS, PROCUREMENT OF SUBSTITUTE GOODS OR
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
+ * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ ********************************************************************************/
+
+#include "mbed.h"
+#include <stdio.h>
+#include <vector>
+#include <string>
+#include "CN0398_Diag.h"
+
+#include "Thermocouple.h"
+
+
+extern Serial pc;
+extern vector<string> cmdbuffer;
+
+//#define CALIBRATION
+#define VH400
+//#define EC5
+
+
+CN0398_Diag::CN0398_Diag(CN0398& ad) :
+ dut(ad), offset_voltage(default_offset_voltage)
+{
+ calibration_ph[0][0] = default_calibration_ph[0][0];
+ calibration_ph[0][1] = default_calibration_ph[0][1];
+ calibration_ph[1][0] = default_calibration_ph[1][0];
+ calibration_ph[1][1] = default_calibration_ph[1][1];
+}
+
+void CN0398_Diag::init()
+{
+ dut.reset();
+ dut.setup();
+ dut.init();
+}
+
+
+void CN0398_Diag::write_reg()
+{
+ uint8_t reg = strtol(cmdbuffer[1].c_str(), NULL, 16);
+ uint32_t regData = strtol(cmdbuffer[2].c_str(), NULL, 16);
+ //dut.write_reg(reg, regData);
+ dut.ad7124.WriteDeviceRegister(static_cast<AD7124::ad7124_registers>(reg),
+ regData);
+ pc.printf("Wrote mode");
+}
+void CN0398_Diag::read_reg()
+{
+ uint8_t regVal = strtol(cmdbuffer[1].c_str(), NULL, 16);
+ pc.printf("Mode reg: %x ",
+ dut.ad7124.ReadDeviceRegister(
+ static_cast<AD7124::ad7124_registers>(regVal)));
+}
+void CN0398_Diag::reset()
+{
+ dut.ad7124.frequency(500000);
+ dut.ad7124.Reset();
+ pc.printf("Reseted AD7124");
+ wait_ms(500);
+}
+
+float CN0398_Diag::data_to_voltage(uint32_t data)
+{
+ data = data & 0xFFFFFF;
+ return ((data / static_cast<float>(0xFFFFFF / 2)) - 1) * (2.5 / 1);
+}
+
+void CN0398_Diag::enable_channel(int channel)
+{
+ dut.enable_channel(channel);
+}
+
+void CN0398_Diag::disable_channel(int channel)
+{
+ dut.disable_channel(channel);
+}
+
+void CN0398_Diag::enable_current_source()
+{
+ dut.enable_current_source0(11);
+ dut.enable_current_source1(12);
+ pc.printf("Enabled 500uA current sources on channel 11, 12\r\n");
+}
+
+void CN0398_Diag::toggle_output(int channel, uint8_t state)
+{
+ dut.set_digital_output(static_cast<CN0398::ad_digital_output_t>(channel), state);
+}
+
+
+void CN0398_Diag::readt()
+{
+
+ //enable_current_source();
+ enable_channel(2);
+ //wait_ms(100);
+ start_single_conversion();
+ //wait_ms(100);
+ if (dut.ad7124.WaitForConvReady(10000) == -3) {
+ pc.printf("TIMEOUT");
+ return;
+ }
+ int32_t data;
+ dut.ad7124.ReadData(&data);
+ disable_channel(2);
+
+ pc.printf("Channel: %d\r\n", data & 0xff);
+ pc.printf("Data reg: %x \r\n", data);
+ float volt = dut.data_to_voltage(data >> 8, 16);
+ pc.printf("Voltage = %f\r\n", volt);
+ data = (data >> 8) & 0x00ffffff;
+ float a1 = (static_cast<float>(data) - (1 << 23));
+ float a2 = a1 * 5000;
+ float a3 = 16.0 * (1 << 23);
+
+ float resistance = a2 / a3; //((data- (1<<23)) * 5000.0) / 16.0*(1<<23) ;
+ pc.printf("Resistance: %f\r\n", resistance);
+ pc.printf("Temperature = %f\r\n", (resistance - 100.0) / 0.385);
+
+}
+
+void CN0398_Diag::readm()
+{
+
+ toggle_output(0, 1);
+#ifdef EC5
+ wait_ms(10);
+#endif
+ enable_channel(1);
+ //wait_ms(100);
+ start_single_conversion();
+ //wait_ms(100);
+ if (dut.ad7124.WaitForConvReady(10000) == -3) {
+ pc.printf("TIMEOUT");
+ return;
+ }
+ int32_t data;
+ dut.ad7124.ReadData(&data);
+ disable_channel(1);
+ toggle_output(0, 0);
+
+ pc.printf("Channel: %d\r\n", data & 0xff);
+ pc.printf("Data reg: %x \r\n", data);
+ float volt = dut.data_to_voltage(data >> 8, 16);
+ pc.printf("Voltage = %f\r\n", volt);
+ data = (data >> 8) & 0x00ffffff;
+
+
+ float moisture;
+#ifdef VH400
+ moisture = -1.18467 + 21.5371 * volt - 110.996 * (pow(volt, 2)) + 397.025 * (pow(volt, 3)) - 666.986 * (pow(volt, 4)) + 569.236 * (pow(volt, 5)) - 246.005 * (pow(volt, 6)) + 49.4867 * (pow(volt, 7)) - 3.37077 * (pow(volt, 8));
+#elif EC5
+ moisture = 0.000992 * (volt * 1000) - 0.45;
+#endif
+ pc.printf("Moisture = %f\r\n", moisture);
+
+
+
+}
+
+void CN0398_Diag::offsetph()
+{
+ enable_channel(0);
+ //wait_ms(100);
+ start_single_conversion();
+ //wait_ms(100);
+ if (dut.ad7124.WaitForConvReady(10000) == -3) {
+ pc.printf("TIMEOUT");
+ return;
+ }
+ int32_t data;
+ dut.ad7124.ReadData(&data);
+ disable_channel(0);
+ pc.printf("Channel: %d\r\n", data & 0xff);
+ pc.printf("Data reg: %x \r\n", data);
+ float volt = dut.data_to_voltage(data >> 8, 1);
+ pc.printf("Voltage = %f\r\n", volt);
+ offset_voltage = volt;
+
+}
+
+void CN0398_Diag::calibp(int point)
+{
+ calibration_ph[point][0] = strtof(cmdbuffer[1].c_str(), NULL);
+ enable_channel(0);
+ start_single_conversion();
+ if (dut.ad7124.WaitForConvReady(10000) == -3) {
+ pc.printf("TIMEOUT");
+ return;
+ }
+ int32_t data;
+ dut.ad7124.ReadData(&data);
+ disable_channel(0);
+ pc.printf("Channel: %d\r\n", data & 0xff);
+ pc.printf("Data reg: %x \r\n", data);
+ float volt = dut.data_to_voltage(data >> 8, 1);
+ pc.printf("Voltage = %f\r\n", volt);
+ calibration_ph[point][1] = volt;
+
+}
+void CN0398_Diag::readp()
+{
+ enable_channel(0);
+ start_single_conversion();
+ if (dut.ad7124.WaitForConvReady(10000) == -3) {
+ pc.printf("TIMEOUT");
+ return;
+ }
+ int32_t data;
+ dut.ad7124.ReadData(&data);
+ disable_channel(0);
+ pc.printf("Channel: %d\r\n", data & 0xff);
+ pc.printf("Data reg: %x \r\n", data);
+ float volt = dut.data_to_voltage(data >> 8, 1);
+ pc.printf("Voltage = %f\r\n", volt);
+ float m = (calibration_ph[1][0] - calibration_ph[0][0]) / (calibration_ph[1][1] - calibration_ph[0][1]);
+ pc.printf("pH = %f", m * (volt - calibration_ph[1][1]) + calibration_ph[1][0]);
+
+}
+
+
+void CN0398_Diag::start_single_conversion()
+{
+ dut.start_single_conversion();
+}
+
+/*void CN0398_Diag::read_data()
+{
+ int32_t data;
+ float volt;
+ float cal_current = 0;
+
+ for(int i = 0; i < 8; i++) {
+ if(i % 2 == 0) {
+ //enable_current_source(i+1);
+ } else {
+ enable_current_source(i);
+ enable_channel(8); // calibration channel
+ start_single_conversion();
+ if (dut.WaitForConvReady(10000) == -3) {
+ pc.printf("TIMEOUT");
+ return;
+ }
+
+ dut.ReadData(&data);
+ disable_channel(8);
+
+ pc.printf("Channel: %d\r\n", data & 0xff);
+ pc.printf("Data reg: %x \r\n", data);
+ volt = data_to_voltage(data >> 8);
+ pc.printf("Voltage = %f\r\n", volt);
+ cal_current = conversion_fkt[8](volt, 0);
+ conversion_results[8] = cal_current;
+
+ }
+
+ enable_channel(i);
+ start_single_conversion();
+
+
+ if (dut.WaitForConvReady(10000) == -3) {
+ pc.printf("TIMEOUT");
+ return;
+ }
+
+ dut.ReadData(&data);
+
+ disable_channel(i);
+
+
+ pc.printf("Channel: %d\r\n", data & 0xff);
+ pc.printf("Data reg: %x \r\n", data);
+ volt = data_to_voltage(data >> 8);
+ pc.printf("Voltage = %f\r\n", volt);
+ conversion_results[i] = conversion_fkt[i](volt, cal_current);
+ pc.printf("\r\n");
+
+ }
+}
+
+void CN0398_Diag::read_volt()
+{
+ uint8_t regVal = strtol(cmdbuffer[1].c_str(), NULL, 16);
+ pc.printf("Data reg: %x ",
+ dut.ReadDeviceRegister(
+ static_cast<AD7124::ad7124_registers>(regVal)));
+}
+*/
CN0357 - Toxic gas measurement
CN0216 - Weight Scale