Test program running on MAX32625MBED. Control through USB Serial commands using a terminal emulator such as teraterm or putty.

Dependencies:   MaximTinyTester CmdLine MAX5171 USBDevice

Committer:
whismanoid
Date:
Thu Jun 20 00:26:29 2019 +0000
Revision:
5:82037e281451
Parent:
3:8913cb4a8b9f
Child:
6:dc823dc85234
remove if-else-endif USE_MAXIMTINYTESTER always 1

Who changed what in which revision?

UserRevisionLine numberNew contents of line
whismanoid 0:3edb3708c8c5 1 /*******************************************************************************
whismanoid 0:3edb3708c8c5 2 * Copyright (C) 2019 Maxim Integrated Products, Inc., All Rights Reserved.
whismanoid 0:3edb3708c8c5 3 *
whismanoid 0:3edb3708c8c5 4 * Permission is hereby granted, free of charge, to any person obtaining a
whismanoid 0:3edb3708c8c5 5 * copy of this software and associated documentation files (the "Software"),
whismanoid 0:3edb3708c8c5 6 * to deal in the Software without restriction, including without limitation
whismanoid 0:3edb3708c8c5 7 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
whismanoid 0:3edb3708c8c5 8 * and/or sell copies of the Software, and to permit persons to whom the
whismanoid 0:3edb3708c8c5 9 * Software is furnished to do so, subject to the following conditions:
whismanoid 0:3edb3708c8c5 10 *
whismanoid 0:3edb3708c8c5 11 * The above copyright notice and this permission notice shall be included
whismanoid 0:3edb3708c8c5 12 * in all copies or substantial portions of the Software.
whismanoid 0:3edb3708c8c5 13 *
whismanoid 0:3edb3708c8c5 14 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
whismanoid 0:3edb3708c8c5 15 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
whismanoid 0:3edb3708c8c5 16 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
whismanoid 0:3edb3708c8c5 17 * IN NO EVENT SHALL MAXIM INTEGRATED BE LIABLE FOR ANY CLAIM, DAMAGES
whismanoid 0:3edb3708c8c5 18 * OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
whismanoid 0:3edb3708c8c5 19 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
whismanoid 0:3edb3708c8c5 20 * OTHER DEALINGS IN THE SOFTWARE.
whismanoid 0:3edb3708c8c5 21 *
whismanoid 0:3edb3708c8c5 22 * Except as contained in this notice, the name of Maxim Integrated
whismanoid 0:3edb3708c8c5 23 * Products, Inc. shall not be used except as stated in the Maxim Integrated
whismanoid 0:3edb3708c8c5 24 * Products, Inc. Branding Policy.
whismanoid 0:3edb3708c8c5 25 *
whismanoid 0:3edb3708c8c5 26 * The mere transfer of this software does not imply any licenses
whismanoid 0:3edb3708c8c5 27 * of trade secrets, proprietary technology, copyrights, patents,
whismanoid 0:3edb3708c8c5 28 * trademarks, maskwork rights, or any other form of intellectual
whismanoid 0:3edb3708c8c5 29 * property whatsoever. Maxim Integrated Products, Inc. retains all
whismanoid 0:3edb3708c8c5 30 * ownership rights.
whismanoid 0:3edb3708c8c5 31 *******************************************************************************
whismanoid 0:3edb3708c8c5 32 */
whismanoid 0:3edb3708c8c5 33
whismanoid 0:3edb3708c8c5 34 //----------------------------------------------------------------------
whismanoid 0:3edb3708c8c5 35 // mbed-os compatability tests...
whismanoid 0:3edb3708c8c5 36 //----------------------------------------------------------------------
whismanoid 0:3edb3708c8c5 37 // mbed-os-5.12: buildable; warnings
whismanoid 0:3edb3708c8c5 38 //
whismanoid 0:3edb3708c8c5 39 // Not supported by MAX32625MBED... better stick with mbed-os-5.11 for now.
whismanoid 0:3edb3708c8c5 40 // Watch out for conflict with USBDevice library.
whismanoid 0:3edb3708c8c5 41 // Now that USBSerial is part of the official mbed-os-5.12 API,
whismanoid 0:3edb3708c8c5 42 // remove the external USBDevice library if present:
whismanoid 0:3edb3708c8c5 43 // mbed remove USBDevice
whismanoid 0:3edb3708c8c5 44 //
whismanoid 0:3edb3708c8c5 45 // cd mbed-os ; mbed update mbed-os-5.12 ; cd ..; mbed remove USBDevice
whismanoid 0:3edb3708c8c5 46 //----------------------------------------------------------------------
whismanoid 0:3edb3708c8c5 47 // mbed-os-5.11: buildable; warnings
whismanoid 0:3edb3708c8c5 48 //
whismanoid 0:3edb3708c8c5 49 // fixed: format '%d' expects argument of type 'int', but argument _ has type 'uint32_t {aka long unsigned int}' [-Wformat=]
whismanoid 0:3edb3708c8c5 50 // fixed: 'static osStatus rtos::Thread::wait(uint32_t)' is deprecated: Static methods only affecting current thread cause confusion. Replaced by ThisThread::sleep_for. [since mbed-os-5.10] [-Wdeprecated-declarations]
whismanoid 0:3edb3708c8c5 51 //
whismanoid 0:3edb3708c8c5 52 // prior to mbed-os-5.12, USBSerial required an external library:
whismanoid 0:3edb3708c8c5 53 // mbed add https://developer.mbed.org/teams/MaximIntegrated/code/USBDevice/
whismanoid 0:3edb3708c8c5 54 //
whismanoid 0:3edb3708c8c5 55 // cd mbed-os ; mbed update mbed-os-5.11
whismanoid 0:3edb3708c8c5 56 // cd .. ; mbed sync
whismanoid 0:3edb3708c8c5 57 //----------------------------------------------------------------------
whismanoid 0:3edb3708c8c5 58 // mbed-os-5.10 buildable; warning about wait function
whismanoid 0:3edb3708c8c5 59 // 'static osStatus rtos::Thread::wait(uint32_t)' is deprecated: Static methods only affecting current thread cause confusion. Replaced by ThisThread::sleep_for. [since mbed-os-5.10] [-Wdeprecated-declarations]
whismanoid 0:3edb3708c8c5 60 //
whismanoid 0:3edb3708c8c5 61 // prior to mbed-os-5.12, USBSerial required an external library:
whismanoid 0:3edb3708c8c5 62 // mbed add https://developer.mbed.org/teams/MaximIntegrated/code/USBDevice/
whismanoid 0:3edb3708c8c5 63 //
whismanoid 0:3edb3708c8c5 64 // cd mbed-os ; mbed update mbed-os-5.10
whismanoid 0:3edb3708c8c5 65 // cd .. ; mbed sync
whismanoid 0:3edb3708c8c5 66 //----------------------------------------------------------------------
whismanoid 0:3edb3708c8c5 67 // mbed-os-5.9 buildable
whismanoid 0:3edb3708c8c5 68 //
whismanoid 0:3edb3708c8c5 69 // prior to mbed-os-5.12, USBSerial required an external library:
whismanoid 0:3edb3708c8c5 70 // mbed add https://developer.mbed.org/teams/MaximIntegrated/code/USBDevice/
whismanoid 0:3edb3708c8c5 71 //
whismanoid 0:3edb3708c8c5 72 // cd mbed-os ; mbed update mbed-os-5.9
whismanoid 0:3edb3708c8c5 73 // cd .. ; mbed sync
whismanoid 0:3edb3708c8c5 74 //----------------------------------------------------------------------
whismanoid 0:3edb3708c8c5 75 // mbed-os-5.8 buildable
whismanoid 0:3edb3708c8c5 76 //
whismanoid 0:3edb3708c8c5 77 // prior to mbed-os-5.12, USBSerial required an external library:
whismanoid 0:3edb3708c8c5 78 // mbed add https://developer.mbed.org/teams/MaximIntegrated/code/USBDevice/
whismanoid 0:3edb3708c8c5 79 //
whismanoid 0:3edb3708c8c5 80 // cd mbed-os ; mbed update mbed-os-5.8
whismanoid 0:3edb3708c8c5 81 // cd .. ; mbed sync
whismanoid 0:3edb3708c8c5 82 //---------------------------------------------------------------------
whismanoid 0:3edb3708c8c5 83 // mbed-os-5.7 buildable
whismanoid 0:3edb3708c8c5 84 //
whismanoid 0:3edb3708c8c5 85 // prior to mbed-os-5.12, USBSerial required an external library:
whismanoid 0:3edb3708c8c5 86 // mbed add https://developer.mbed.org/teams/MaximIntegrated/code/USBDevice/
whismanoid 0:3edb3708c8c5 87 //
whismanoid 0:3edb3708c8c5 88 // cd mbed-os ; mbed update mbed-os-5.7
whismanoid 0:3edb3708c8c5 89 // cd .. ; mbed sync
whismanoid 0:3edb3708c8c5 90 //----------------------------------------------------------------------
whismanoid 0:3edb3708c8c5 91 // mbed-os-5.6 pass
whismanoid 0:3edb3708c8c5 92 // [Warning] USBSerial.h@59,203: 'mbed::FunctionPointerArg1<R, void>::FunctionPointerArg1(R (*)()) [with R = void]' is deprecated: FunctionPointer has been replaced by Callback<void()> [since mbed-os-5.1] [-Wdeprecated-declarations]
whismanoid 0:3edb3708c8c5 93 // [Warning] USBSerial.h@134,27: 'void mbed::Callback<R()>::attach(R (*)()) [with R = void]' is deprecated: Replaced by simple assignment 'Callback cb = func [since mbed-os-5.4] [-Wdeprecated-declarations]
whismanoid 0:3edb3708c8c5 94 //
whismanoid 0:3edb3708c8c5 95 // prior to mbed-os-5.12, USBSerial required an external library:
whismanoid 0:3edb3708c8c5 96 // mbed add https://developer.mbed.org/teams/MaximIntegrated/code/USBDevice/
whismanoid 0:3edb3708c8c5 97 //
whismanoid 0:3edb3708c8c5 98 // cd mbed-os ; mbed update mbed-os-5.6
whismanoid 0:3edb3708c8c5 99 // cd .. ; mbed sync
whismanoid 0:3edb3708c8c5 100 //----------------------------------------------------------------------
whismanoid 0:3edb3708c8c5 101
whismanoid 0:3edb3708c8c5 102 // Test fixture and application menu for breakout boards:
whismanoid 0:3edb3708c8c5 103 // - MAX5715BOB
whismanoid 0:3edb3708c8c5 104 // - MAX11131BOB
whismanoid 0:3edb3708c8c5 105 // - MAX5171BOB
whismanoid 0:3edb3708c8c5 106 // Platforms:
whismanoid 0:3edb3708c8c5 107 // - MAX32625MBED
whismanoid 0:3edb3708c8c5 108 // - NUCLEO_F446RE
whismanoid 0:3edb3708c8c5 109 // - NUCLEO_F401RE
whismanoid 0:3edb3708c8c5 110
whismanoid 0:3edb3708c8c5 111 #include "mbed.h"
whismanoid 0:3edb3708c8c5 112 #if defined(TARGET)
whismanoid 0:3edb3708c8c5 113 // TARGET_NAME macros from targets/TARGET_Maxim/TARGET_MAX32625/device/mxc_device.h
whismanoid 0:3edb3708c8c5 114 // Create a string definition for the TARGET
whismanoid 0:3edb3708c8c5 115 #define STRING_ARG(arg) #arg
whismanoid 0:3edb3708c8c5 116 #define STRING_NAME(name) STRING_ARG(name)
whismanoid 0:3edb3708c8c5 117 #define TARGET_NAME STRING_NAME(TARGET)
whismanoid 0:3edb3708c8c5 118 #elif defined(TARGET_LPC1768)
whismanoid 0:3edb3708c8c5 119 #define TARGET_NAME "LPC1768"
whismanoid 0:3edb3708c8c5 120 #elif defined(TARGET_NUCLEO_F446RE)
whismanoid 0:3edb3708c8c5 121 #define TARGET_NAME "NUCLEO_F446RE"
whismanoid 0:3edb3708c8c5 122 #elif defined(TARGET_NUCLEO_F401RE)
whismanoid 0:3edb3708c8c5 123 #define TARGET_NAME "NUCLEO_F401RE"
whismanoid 0:3edb3708c8c5 124 #else
whismanoid 0:3edb3708c8c5 125 #error TARGET NOT DEFINED
whismanoid 0:3edb3708c8c5 126 #endif
whismanoid 0:3edb3708c8c5 127 #if defined(TARGET_MAX32630)
whismanoid 0:3edb3708c8c5 128 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 129 // TARGET=MAX32630FTHR ARM Cortex-M4F 96MHz 2048kB Flash 512kB SRAM
whismanoid 0:3edb3708c8c5 130 // +-------------[microUSB]-------------+
whismanoid 0:3edb3708c8c5 131 // | J1 MAX32630FTHR J2 |
whismanoid 0:3edb3708c8c5 132 // ______ | [ ] RST GND [ ] |
whismanoid 0:3edb3708c8c5 133 // ______ | [ ] 3V3 BAT+[ ] |
whismanoid 0:3edb3708c8c5 134 // ______ | [ ] 1V8 reset SW1 |
whismanoid 0:3edb3708c8c5 135 // ______ | [ ] GND J4 J3 |
whismanoid 0:3edb3708c8c5 136 // analogIn0/4 | [a] AIN_0 1.2Vfs (bat) SYS [ ] | switched BAT+
whismanoid 0:3edb3708c8c5 137 // analogIn1/5 | [a] AIN_1 1.2Vfs PWR [ ] | external pwr btn
whismanoid 0:3edb3708c8c5 138 // analogIn2 | [a] AIN_2 1.2Vfs +5V VBUS [ ] | USB +5V power
whismanoid 0:3edb3708c8c5 139 // analogIn3 | [a] AIN_3 1.2Vfs 1-WIRE P4_0 [d] | dig9
whismanoid 0:3edb3708c8c5 140 // (I2C2.SDA) | [d] P5_7 SDA2 SRN P5_6 [d] | dig8
whismanoid 0:3edb3708c8c5 141 // (I2C2.SCL) | [d] P6_0 SCL2 SDIO3 P5_5 [d] | dig7
whismanoid 0:3edb3708c8c5 142 // (SPI.SCLK) | [s] P5_0 SCLK SDIO2 P5_4 [d] | dig6
whismanoid 0:3edb3708c8c5 143 // (SPI.MOSI) | [s] P5_1 MOSI SSEL P5_3 [d] | dig5
whismanoid 0:3edb3708c8c5 144 // (SPI.MISO) | [s] P5_2 MISO RTS P3_3 [d] | dig4
whismanoid 0:3edb3708c8c5 145 // (SPI.CS ) | [s] P3_0 RX CTS P3_2 [d] | dig3
whismanoid 0:3edb3708c8c5 146 // dig0 | [d] P3_1 TX SCL P3_5 [d] | dig2
whismanoid 0:3edb3708c8c5 147 // ______ | [ ] GND SDA P3_4 [d] | dig1
whismanoid 0:3edb3708c8c5 148 // | |
whismanoid 0:3edb3708c8c5 149 // | XIP Flash MAX14690N |
whismanoid 0:3edb3708c8c5 150 // | XIP_SCLK P1_0 SDA2 P5_7 |
whismanoid 0:3edb3708c8c5 151 // | XIP_MOSI P1_1 SCL2 P6_0 |
whismanoid 0:3edb3708c8c5 152 // | XIP_MISO P1_2 PMIC_INIT P3_7 |
whismanoid 0:3edb3708c8c5 153 // | XIP_SSEL P1_3 MPC P2_7 |
whismanoid 0:3edb3708c8c5 154 // | XIP_DIO2 P1_4 MON AIN_0 |
whismanoid 0:3edb3708c8c5 155 // | XIP_DIO3 P1_5 |
whismanoid 0:3edb3708c8c5 156 // | |
whismanoid 0:3edb3708c8c5 157 // | PAN1326B MicroSD LED |
whismanoid 0:3edb3708c8c5 158 // | BT_RX P0_0 SD_SCLK P0_4 r P2_4 |
whismanoid 0:3edb3708c8c5 159 // | BT_TX P0_1 SD_MOSI P0_5 g P2_5 |
whismanoid 0:3edb3708c8c5 160 // | BT_CTS P0_2 SD_MISO P0_6 b P2_6 |
whismanoid 0:3edb3708c8c5 161 // | BT_RTS P0_3 SD_SSEL P0_7 |
whismanoid 0:3edb3708c8c5 162 // | BT_RST P1_6 DETECT P2_2 |
whismanoid 0:3edb3708c8c5 163 // | BT_CLK P1_7 SW2 P2_3 |
whismanoid 0:3edb3708c8c5 164 // +------------------------------------+
whismanoid 0:3edb3708c8c5 165 // MAX32630FTHR board has MAX14690 PMIC on I2C bus (P5_7 SDA, P6_0 SCL) at slave address 0101_000r 0x50 (or 0x28 for 7 MSbit address).
whismanoid 0:3edb3708c8c5 166 // MAX32630FTHR board has BMI160 accelerometer on I2C bus (P5_7 SDA, P6_0 SCL) at slave address 1101_000r 0xD0 (or 0x68 for 7 MSbit address).
whismanoid 0:3edb3708c8c5 167 // AIN_0 = AIN0 pin fullscale is 1.2V
whismanoid 0:3edb3708c8c5 168 // AIN_1 = AIN1 pin fullscale is 1.2V
whismanoid 0:3edb3708c8c5 169 // AIN_2 = AIN2 pin fullscale is 1.2V
whismanoid 0:3edb3708c8c5 170 // AIN_3 = AIN3 pin fullscale is 1.2V
whismanoid 0:3edb3708c8c5 171 // AIN_4 = AIN0 / 5.0 fullscale is 6.0V
whismanoid 0:3edb3708c8c5 172 // AIN_5 = AIN1 / 5.0 fullscale is 6.0V
whismanoid 0:3edb3708c8c5 173 // AIN_6 = VDDB / 4.0 fullscale is 4.8V
whismanoid 0:3edb3708c8c5 174 // AIN_7 = VDD18 fullscale is 1.2V
whismanoid 0:3edb3708c8c5 175 // AIN_8 = VDD12 fullscale is 1.2V
whismanoid 0:3edb3708c8c5 176 // AIN_9 = VRTC / 2.0 fullscale is 2.4V
whismanoid 0:3edb3708c8c5 177 // AIN_10 = x undefined?
whismanoid 0:3edb3708c8c5 178 // AIN_11 = VDDIO / 4.0 fullscale is 4.8V
whismanoid 0:3edb3708c8c5 179 // AIN_12 = VDDIOH / 4.0 fullscale is 4.8V
whismanoid 0:3edb3708c8c5 180 //
whismanoid 0:3edb3708c8c5 181 #include "max32630fthr.h"
whismanoid 0:3edb3708c8c5 182 MAX32630FTHR pegasus(MAX32630FTHR::VIO_3V3);
whismanoid 0:3edb3708c8c5 183 #define analogIn4_IS_HIGH_RANGE_OF_analogIn0 1
whismanoid 0:3edb3708c8c5 184 // MAX32630FTHR board supports only internal VREF = 1.200V at bypass capacitor C15
whismanoid 0:3edb3708c8c5 185 const float ADC_FULL_SCALE_VOLTAGE = 1.200;
whismanoid 0:3edb3708c8c5 186 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 187 #elif defined(TARGET_MAX32625MBED)
whismanoid 0:3edb3708c8c5 188 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 189 // TARGET=MAX32625MBED ARM Cortex-M4F 96MHz 512kB Flash 160kB SRAM
whismanoid 0:3edb3708c8c5 190 // +-------------------------------------+
whismanoid 0:3edb3708c8c5 191 // | MAX32625MBED Arduino UNO header |
whismanoid 0:3edb3708c8c5 192 // | |
whismanoid 0:3edb3708c8c5 193 // | A5/SCL[ ] | P1_7 dig15
whismanoid 0:3edb3708c8c5 194 // | A4/SDA[ ] | P1_6 dig14
whismanoid 0:3edb3708c8c5 195 // | AREF=N/C[ ] |
whismanoid 0:3edb3708c8c5 196 // | GND[ ] |
whismanoid 0:3edb3708c8c5 197 // | [ ]N/C SCK/13[ ] | P1_0 dig13
whismanoid 0:3edb3708c8c5 198 // | [ ]IOREF=3V3 MISO/12[ ] | P1_2 dig12
whismanoid 0:3edb3708c8c5 199 // | [ ]RST MOSI/11[ ]~| P1_1 dig11
whismanoid 0:3edb3708c8c5 200 // | [ ]3V3 CS/10[ ]~| P1_3 dig10
whismanoid 0:3edb3708c8c5 201 // | [ ]5V0 9[ ]~| P1_5 dig9
whismanoid 0:3edb3708c8c5 202 // | [ ]GND 8[ ] | P1_4 dig8
whismanoid 0:3edb3708c8c5 203 // | [ ]GND |
whismanoid 0:3edb3708c8c5 204 // | [ ]Vin 7[ ] | P0_7 dig7
whismanoid 0:3edb3708c8c5 205 // | 6[ ]~| P0_6 dig6
whismanoid 0:3edb3708c8c5 206 // AIN_0 | [ ]A0 5[ ]~| P0_5 dig5
whismanoid 0:3edb3708c8c5 207 // AIN_1 | [ ]A1 4[ ] | P0_4 dig4
whismanoid 0:3edb3708c8c5 208 // AIN_2 | [ ]A2 INT1/3[ ]~| P0_3 dig3
whismanoid 0:3edb3708c8c5 209 // AIN_3 | [ ]A3 INT0/2[ ] | P0_2 dig2
whismanoid 0:3edb3708c8c5 210 // dig16 P3_4 | [ ]A4/SDA RST SCK MISO TX>1[ ] | P0_1 dig1
whismanoid 0:3edb3708c8c5 211 // dig17 P3_5 | [ ]A5/SCL [ ] [ ] [ ] RX<0[ ] | P0_0 dig0
whismanoid 0:3edb3708c8c5 212 // | [ ] [ ] [ ] |
whismanoid 0:3edb3708c8c5 213 // | UNO_R3 GND MOSI 5V ____________/
whismanoid 0:3edb3708c8c5 214 // \_______________________/
whismanoid 0:3edb3708c8c5 215 //
whismanoid 0:3edb3708c8c5 216 // +------------------------+
whismanoid 0:3edb3708c8c5 217 // | |
whismanoid 0:3edb3708c8c5 218 // | MicroSD LED |
whismanoid 0:3edb3708c8c5 219 // | SD_SCLK P2_4 r P3_0 |
whismanoid 0:3edb3708c8c5 220 // | SD_MOSI P2_5 g P3_1 |
whismanoid 0:3edb3708c8c5 221 // | SD_MISO P2_6 b P3_2 |
whismanoid 0:3edb3708c8c5 222 // | SD_SSEL P2_7 y P3_3 |
whismanoid 0:3edb3708c8c5 223 // | |
whismanoid 0:3edb3708c8c5 224 // | DAPLINK BUTTONS |
whismanoid 0:3edb3708c8c5 225 // | TX P2_1 SW3 P2_3 |
whismanoid 0:3edb3708c8c5 226 // | RX P2_0 SW2 P2_2 |
whismanoid 0:3edb3708c8c5 227 // +------------------------+
whismanoid 0:3edb3708c8c5 228 //
whismanoid 0:3edb3708c8c5 229 // AIN_0 = AIN0 pin fullscale is 1.2V
whismanoid 0:3edb3708c8c5 230 // AIN_1 = AIN1 pin fullscale is 1.2V
whismanoid 0:3edb3708c8c5 231 // AIN_2 = AIN2 pin fullscale is 1.2V
whismanoid 0:3edb3708c8c5 232 // AIN_3 = AIN3 pin fullscale is 1.2V
whismanoid 0:3edb3708c8c5 233 // AIN_4 = AIN0 / 5.0 fullscale is 6.0V
whismanoid 0:3edb3708c8c5 234 // AIN_5 = AIN1 / 5.0 fullscale is 6.0V
whismanoid 0:3edb3708c8c5 235 // AIN_6 = VDDB / 4.0 fullscale is 4.8V
whismanoid 0:3edb3708c8c5 236 // AIN_7 = VDD18 fullscale is 1.2V
whismanoid 0:3edb3708c8c5 237 // AIN_8 = VDD12 fullscale is 1.2V
whismanoid 0:3edb3708c8c5 238 // AIN_9 = VRTC / 2.0 fullscale is 2.4V
whismanoid 0:3edb3708c8c5 239 // AIN_10 = x undefined?
whismanoid 0:3edb3708c8c5 240 // AIN_11 = VDDIO / 4.0 fullscale is 4.8V
whismanoid 0:3edb3708c8c5 241 // AIN_12 = VDDIOH / 4.0 fullscale is 4.8V
whismanoid 0:3edb3708c8c5 242 //
whismanoid 0:3edb3708c8c5 243 //#include "max32625mbed.h" // ?
whismanoid 0:3edb3708c8c5 244 //MAX32625MBED mbed(MAX32625MBED::VIO_3V3); // ?
whismanoid 0:3edb3708c8c5 245 #define analogIn4_IS_HIGH_RANGE_OF_analogIn0 1
whismanoid 0:3edb3708c8c5 246 // MAX32630FTHR board supports only internal VREF = 1.200V at bypass capacitor C15
whismanoid 0:3edb3708c8c5 247 const float ADC_FULL_SCALE_VOLTAGE = 1.200; // TODO: ADC_FULL_SCALE_VOLTAGE Pico?
whismanoid 0:3edb3708c8c5 248 // Arduino connector
whismanoid 0:3edb3708c8c5 249 #ifndef A0
whismanoid 0:3edb3708c8c5 250 #define A0 AIN_0
whismanoid 0:3edb3708c8c5 251 #endif
whismanoid 0:3edb3708c8c5 252 #ifndef A1
whismanoid 0:3edb3708c8c5 253 #define A1 AIN_1
whismanoid 0:3edb3708c8c5 254 #endif
whismanoid 0:3edb3708c8c5 255 #ifndef A2
whismanoid 0:3edb3708c8c5 256 #define A2 AIN_2
whismanoid 0:3edb3708c8c5 257 #endif
whismanoid 0:3edb3708c8c5 258 #ifndef A3
whismanoid 0:3edb3708c8c5 259 #define A3 AIN_3
whismanoid 0:3edb3708c8c5 260 #endif
whismanoid 0:3edb3708c8c5 261 #ifndef D0
whismanoid 0:3edb3708c8c5 262 #define D0 P0_0
whismanoid 0:3edb3708c8c5 263 #endif
whismanoid 0:3edb3708c8c5 264 #ifndef D1
whismanoid 0:3edb3708c8c5 265 #define D1 P0_1
whismanoid 0:3edb3708c8c5 266 #endif
whismanoid 0:3edb3708c8c5 267 #ifndef D2
whismanoid 0:3edb3708c8c5 268 #define D2 P0_2
whismanoid 0:3edb3708c8c5 269 #endif
whismanoid 0:3edb3708c8c5 270 #ifndef D3
whismanoid 0:3edb3708c8c5 271 #define D3 P0_3
whismanoid 0:3edb3708c8c5 272 #endif
whismanoid 0:3edb3708c8c5 273 #ifndef D4
whismanoid 0:3edb3708c8c5 274 #define D4 P0_4
whismanoid 0:3edb3708c8c5 275 #endif
whismanoid 0:3edb3708c8c5 276 #ifndef D5
whismanoid 0:3edb3708c8c5 277 #define D5 P0_5
whismanoid 0:3edb3708c8c5 278 #endif
whismanoid 0:3edb3708c8c5 279 #ifndef D6
whismanoid 0:3edb3708c8c5 280 #define D6 P0_6
whismanoid 0:3edb3708c8c5 281 #endif
whismanoid 0:3edb3708c8c5 282 #ifndef D7
whismanoid 0:3edb3708c8c5 283 #define D7 P0_7
whismanoid 0:3edb3708c8c5 284 #endif
whismanoid 0:3edb3708c8c5 285 #ifndef D8
whismanoid 0:3edb3708c8c5 286 #define D8 P1_4
whismanoid 0:3edb3708c8c5 287 #endif
whismanoid 0:3edb3708c8c5 288 #ifndef D9
whismanoid 0:3edb3708c8c5 289 #define D9 P1_5
whismanoid 0:3edb3708c8c5 290 #endif
whismanoid 0:3edb3708c8c5 291 #ifndef D10
whismanoid 0:3edb3708c8c5 292 #define D10 P1_3
whismanoid 0:3edb3708c8c5 293 #endif
whismanoid 0:3edb3708c8c5 294 #ifndef D11
whismanoid 0:3edb3708c8c5 295 #define D11 P1_1
whismanoid 0:3edb3708c8c5 296 #endif
whismanoid 0:3edb3708c8c5 297 #ifndef D12
whismanoid 0:3edb3708c8c5 298 #define D12 P1_2
whismanoid 0:3edb3708c8c5 299 #endif
whismanoid 0:3edb3708c8c5 300 #ifndef D13
whismanoid 0:3edb3708c8c5 301 #define D13 P1_0
whismanoid 0:3edb3708c8c5 302 #endif
whismanoid 0:3edb3708c8c5 303 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 304 #elif defined(TARGET_NUCLEO_F446RE) || defined(TARGET_NUCLEO_F401RE)
whismanoid 0:3edb3708c8c5 305 // TODO1: target NUCLEO_F446RE
whismanoid 0:3edb3708c8c5 306 //
whismanoid 0:3edb3708c8c5 307 // USER_BUTTON PC13
whismanoid 0:3edb3708c8c5 308 // LED1 is shared with SPI_SCK on NUCLEO_F446RE PA_5, so don't use LED1.
whismanoid 0:3edb3708c8c5 309 #define USE_LEDS 0
whismanoid 0:3edb3708c8c5 310 // SPI spi(SPI_MOSI, SPI_MISO, SPI_SCK);
whismanoid 0:3edb3708c8c5 311 // Serial microUSBserial(SERIAL_TX, SERIAL_RX);
whismanoid 0:3edb3708c8c5 312 #define analogIn4_IS_HIGH_RANGE_OF_analogIn0 0
whismanoid 0:3edb3708c8c5 313 const float ADC_FULL_SCALE_VOLTAGE = 3.300; // TODO: ADC_FULL_SCALE_VOLTAGE Pico?
whismanoid 0:3edb3708c8c5 314 //
whismanoid 0:3edb3708c8c5 315 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 316 #elif defined(TARGET_LPC1768)
whismanoid 0:3edb3708c8c5 317 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 318 // TARGET=LPC1768 ARM Cortex-M3 100 MHz 512kB flash 64kB SRAM
whismanoid 0:3edb3708c8c5 319 // +-------------[microUSB]-------------+
whismanoid 0:3edb3708c8c5 320 // ______ | [ ] GND +3.3V VOUT [ ] | ______
whismanoid 0:3edb3708c8c5 321 // ______ | [ ] 4.5V<VIN<9.0V +5.0V VU [ ] | ______
whismanoid 0:3edb3708c8c5 322 // ______ | [ ] VB USB.IF- [ ] | ______
whismanoid 0:3edb3708c8c5 323 // ______ | [ ] nR USB.IF+ [ ] | ______
whismanoid 0:3edb3708c8c5 324 // digitalInOut0 | [ ] p5 MOSI ETHERNET.RD- [ ] | ______
whismanoid 0:3edb3708c8c5 325 // digitalInOut1 | [ ] p6 MISO ETHERNET.RD+ [ ] | ______
whismanoid 0:3edb3708c8c5 326 // digitalInOut2 | [ ] p7 SCLK ETHERNET.TD- [ ] | ______
whismanoid 0:3edb3708c8c5 327 // digitalInOut3 | [ ] p8 ETHERNET.TD+ [ ] | ______
whismanoid 0:3edb3708c8c5 328 // digitalInOut4 | [ ] p9 TX SDA USB.D- [ ] | ______
whismanoid 0:3edb3708c8c5 329 // digitalInOut5 | [ ] p10 RX SCL USB.D+ [ ] | ______
whismanoid 0:3edb3708c8c5 330 // digitalInOut6 | [ ] p11 MOSI CAN-RD p30 [ ] | digitalInOut13
whismanoid 0:3edb3708c8c5 331 // digitalInOut7 | [ ] p12 MISO CAN-TD p29 [ ] | digitalInOut12
whismanoid 0:3edb3708c8c5 332 // digitalInOut8 | [ ] p13 TX SCLK SDA TX p28 [ ] | digitalInOut11
whismanoid 0:3edb3708c8c5 333 // digitalInOut9 | [ ] p14 RX SCL RX p27 [ ] | digitalInOut10
whismanoid 0:3edb3708c8c5 334 // analogIn0 | [ ] p15 AIN0 3.3Vfs PWM1 p26 [ ] | pwmDriver1
whismanoid 0:3edb3708c8c5 335 // analogIn1 | [ ] p16 AIN1 3.3Vfs PWM2 p25 [ ] | pwmDriver2
whismanoid 0:3edb3708c8c5 336 // analogIn2 | [ ] p17 AIN2 3.3Vfs PWM3 p24 [ ] | pwmDriver3
whismanoid 0:3edb3708c8c5 337 // analogIn3 | [ ] p18 AIN3 AOUT PWM4 p23 [ ] | pwmDriver4
whismanoid 0:3edb3708c8c5 338 // analogIn4 | [ ] p19 AIN4 3.3Vfs PWM5 p22 [ ] | pwmDriver5
whismanoid 0:3edb3708c8c5 339 // analogIn5 | [ ] p20 AIN5 3.3Vfs PWM6 p21 [ ] | pwmDriver6
whismanoid 0:3edb3708c8c5 340 // +------------------------------------+
whismanoid 0:3edb3708c8c5 341 // AIN6 = P0.3 = TGT_SBL_RXD?
whismanoid 0:3edb3708c8c5 342 // AIN7 = P0.2 = TGT_SBL_TXD?
whismanoid 0:3edb3708c8c5 343 //
whismanoid 0:3edb3708c8c5 344 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 345 // LPC1768 board uses VREF = 3.300V +A3,3V thru L1 to bypass capacitor C14
whismanoid 0:3edb3708c8c5 346 #define analogIn4_IS_HIGH_RANGE_OF_analogIn0 0
whismanoid 0:3edb3708c8c5 347 const float ADC_FULL_SCALE_VOLTAGE = 3.300;
whismanoid 0:3edb3708c8c5 348 #else // not defined(TARGET_LPC1768 etc.)
whismanoid 0:3edb3708c8c5 349 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 350 // unknown target
whismanoid 0:3edb3708c8c5 351 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 352 #endif // target definition
whismanoid 0:3edb3708c8c5 353
whismanoid 0:3edb3708c8c5 354
whismanoid 0:3edb3708c8c5 355 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 356 // alphanumeric command codes A-Z,a-z,0-9 reserved for application use
whismanoid 0:3edb3708c8c5 357 #ifndef APPLICATION_ArduinoPinsMonitor
whismanoid 0:3edb3708c8c5 358 #define APPLICATION_ArduinoPinsMonitor 1
whismanoid 0:3edb3708c8c5 359 #endif // APPLICATION_ArduinoPinsMonitor
whismanoid 0:3edb3708c8c5 360
whismanoid 0:3edb3708c8c5 361 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 362 // Support MAX5715BOB Breakout Board
whismanoid 0:3edb3708c8c5 363 #ifndef APPLICATION_MAX5715
whismanoid 0:3edb3708c8c5 364 #define APPLICATION_MAX5715 1
whismanoid 0:3edb3708c8c5 365 #endif // APPLICATION_MAX5715
whismanoid 0:3edb3708c8c5 366 #if APPLICATION_MAX5715 // header file
whismanoid 0:3edb3708c8c5 367 #include "MAX5715.h"
whismanoid 0:3edb3708c8c5 368 // suppress the I2C diagnostics, not relevant to this chip
whismanoid 0:3edb3708c8c5 369 #define HAS_I2C 0
whismanoid 0:3edb3708c8c5 370 #endif // APPLICATION_MAX5715
whismanoid 0:3edb3708c8c5 371
whismanoid 0:3edb3708c8c5 372 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 373 // Support MAX11131BOB Breakout Board
whismanoid 0:3edb3708c8c5 374 #ifndef APPLICATION_MAX11131
whismanoid 0:3edb3708c8c5 375 #define APPLICATION_MAX11131 0
whismanoid 0:3edb3708c8c5 376 #endif // APPLICATION_MAX11131
whismanoid 0:3edb3708c8c5 377 #if APPLICATION_MAX11131 // header file
whismanoid 0:3edb3708c8c5 378 #include "MAX11131.h"
whismanoid 0:3edb3708c8c5 379 // suppress the I2C diagnostics, not relevant to this chip
whismanoid 0:3edb3708c8c5 380 #define HAS_I2C 0
whismanoid 0:3edb3708c8c5 381 #endif // APPLICATION_MAX11131
whismanoid 0:3edb3708c8c5 382
whismanoid 0:3edb3708c8c5 383 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 384 // Support MAX5171BOB Breakout Board
whismanoid 0:3edb3708c8c5 385 #ifndef APPLICATION_MAX5171
whismanoid 0:3edb3708c8c5 386 #define APPLICATION_MAX5171 0
whismanoid 0:3edb3708c8c5 387 #endif // APPLICATION_MAX5171
whismanoid 0:3edb3708c8c5 388 #if APPLICATION_MAX5171 // header file
whismanoid 0:3edb3708c8c5 389 #include "MAX5171.h"
whismanoid 0:3edb3708c8c5 390 // suppress the I2C diagnostics, not relevant to this chip
whismanoid 0:3edb3708c8c5 391 #define HAS_I2C 0
whismanoid 0:3edb3708c8c5 392 #endif // APPLICATION_MAX5171
whismanoid 0:3edb3708c8c5 393
whismanoid 0:3edb3708c8c5 394 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 395 // Support MAX11410BOB Breakout Board (placeholder)
whismanoid 0:3edb3708c8c5 396 #ifndef APPLICATION_MAX11410
whismanoid 0:3edb3708c8c5 397 #define APPLICATION_MAX11410 0
whismanoid 0:3edb3708c8c5 398 #endif // APPLICATION_MAX11410
whismanoid 0:3edb3708c8c5 399 #if APPLICATION_MAX11410 // header file
whismanoid 0:3edb3708c8c5 400 #include "MAX11410.h"
whismanoid 0:3edb3708c8c5 401 #endif // APPLICATION_MAX11410
whismanoid 0:3edb3708c8c5 402
whismanoid 0:3edb3708c8c5 403 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 404 // Support MAX12345BOB Breakout Board (placeholder)
whismanoid 0:3edb3708c8c5 405 #ifndef APPLICATION_MAX12345
whismanoid 0:3edb3708c8c5 406 #define APPLICATION_MAX12345 0
whismanoid 0:3edb3708c8c5 407 #endif // APPLICATION_MAX12345
whismanoid 0:3edb3708c8c5 408 #if APPLICATION_MAX12345 // header file
whismanoid 0:3edb3708c8c5 409 #include "MAX12345.h"
whismanoid 0:3edb3708c8c5 410 #endif // APPLICATION_MAX12345
whismanoid 0:3edb3708c8c5 411
whismanoid 0:3edb3708c8c5 412
whismanoid 0:3edb3708c8c5 413 #include "MAX541.h"
whismanoid 0:3edb3708c8c5 414
whismanoid 0:3edb3708c8c5 415 #include "MaximTinyTester.h"
whismanoid 0:3edb3708c8c5 416
whismanoid 0:3edb3708c8c5 417 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 418 // Option to dedicate SPI port pins
whismanoid 0:3edb3708c8c5 419 //
whismanoid 0:3edb3708c8c5 420 // SPI2_MOSI = P5_1
whismanoid 0:3edb3708c8c5 421 // SPI2_MISO = P5_2
whismanoid 0:3edb3708c8c5 422 // SPI2_SCK = P5_0
whismanoid 0:3edb3708c8c5 423 // On this board I'm using P3_0 as spi_cs
whismanoid 0:3edb3708c8c5 424 // SPI2_SS = P5_3
whismanoid 0:3edb3708c8c5 425 // SPI2_SDIO2 = P5_4
whismanoid 0:3edb3708c8c5 426 // SPI2_SDIO3 = P5_5
whismanoid 0:3edb3708c8c5 427 // SPI2_SRN = P5_6
whismanoid 0:3edb3708c8c5 428 //
whismanoid 0:3edb3708c8c5 429 #ifndef HAS_SPI
whismanoid 0:3edb3708c8c5 430 #define HAS_SPI 1
whismanoid 0:3edb3708c8c5 431 #endif
whismanoid 0:3edb3708c8c5 432 #if HAS_SPI
whismanoid 0:3edb3708c8c5 433 #define SPI_MODE0 0
whismanoid 0:3edb3708c8c5 434 #define SPI_MODE1 1
whismanoid 0:3edb3708c8c5 435 #define SPI_MODE2 2
whismanoid 0:3edb3708c8c5 436 #define SPI_MODE3 3
whismanoid 0:3edb3708c8c5 437 //
whismanoid 0:3edb3708c8c5 438 // Define application-specific default SPI_SCLK_Hz and SPI_dataMode
whismanoid 0:3edb3708c8c5 439 #if APPLICATION_MAX5715 // SPI interface default settings
whismanoid 0:3edb3708c8c5 440 //
whismanoid 0:3edb3708c8c5 441 //#define SPI_SCLK_Hz 48000000 // 48MHz
whismanoid 0:3edb3708c8c5 442 //#define SPI_SCLK_Hz 24000000 // 24MHz
whismanoid 0:3edb3708c8c5 443 #define SPI_SCLK_Hz 12000000 // 12MHz
whismanoid 0:3edb3708c8c5 444 //#define SPI_SCLK_Hz 4000000 // 4MHz
whismanoid 0:3edb3708c8c5 445 //#define SPI_SCLK_Hz 2000000 // 2MHz
whismanoid 0:3edb3708c8c5 446 //#define SPI_SCLK_Hz 1000000 // 1MHz
whismanoid 0:3edb3708c8c5 447 #define SPI_dataMode SPI_MODE2 // CPOL=1,CPHA=0: Falling Edge stable; SCLK idle High
whismanoid 0:3edb3708c8c5 448 //
whismanoid 0:3edb3708c8c5 449 #elif APPLICATION_MAX11131 // SPI interface default settings
whismanoid 0:3edb3708c8c5 450 //
whismanoid 0:3edb3708c8c5 451 //#define SPI_SCLK_Hz 48000000 // 48MHz
whismanoid 0:3edb3708c8c5 452 //#define SPI_SCLK_Hz 24000000 // 24MHz
whismanoid 0:3edb3708c8c5 453 #define SPI_SCLK_Hz 12000000 // 12MHz
whismanoid 0:3edb3708c8c5 454 //#define SPI_SCLK_Hz 4000000 // 4MHz
whismanoid 0:3edb3708c8c5 455 //#define SPI_SCLK_Hz 2000000 // 2MHz
whismanoid 0:3edb3708c8c5 456 //#define SPI_SCLK_Hz 1000000 // 1MHz
whismanoid 0:3edb3708c8c5 457 #define SPI_dataMode SPI_MODE3 // CPOL=1,CPHA=1: Rising Edge stable; SCLK idle High
whismanoid 0:3edb3708c8c5 458 //
whismanoid 0:3edb3708c8c5 459 #elif APPLICATION_MAX5171 // SPI interface default settings
whismanoid 0:3edb3708c8c5 460 //
whismanoid 0:3edb3708c8c5 461 //#define SPI_SCLK_Hz 48000000 // 48MHz
whismanoid 0:3edb3708c8c5 462 //#define SPI_SCLK_Hz 24000000 // 24MHz
whismanoid 0:3edb3708c8c5 463 #define SPI_SCLK_Hz 12000000 // 12MHz
whismanoid 0:3edb3708c8c5 464 //#define SPI_SCLK_Hz 4000000 // 4MHz
whismanoid 0:3edb3708c8c5 465 //#define SPI_SCLK_Hz 2000000 // 2MHz
whismanoid 0:3edb3708c8c5 466 //#define SPI_SCLK_Hz 1000000 // 1MHz
whismanoid 0:3edb3708c8c5 467 #define SPI_dataMode SPI_MODE3 // CPOL=1,CPHA=1: Rising Edge stable; SCLK idle High
whismanoid 0:3edb3708c8c5 468 //
whismanoid 0:3edb3708c8c5 469 #elif APPLICATION_MAX11410 // SPI interface default settings
whismanoid 0:3edb3708c8c5 470 //
whismanoid 0:3edb3708c8c5 471 //#define SPI_SCLK_Hz 48000000 // 48MHz
whismanoid 0:3edb3708c8c5 472 //#define SPI_SCLK_Hz 24000000 // 24MHz
whismanoid 0:3edb3708c8c5 473 //#define SPI_SCLK_Hz 12000000 // 12MHz
whismanoid 0:3edb3708c8c5 474 #define SPI_SCLK_Hz 8000000 // 8MHz
whismanoid 0:3edb3708c8c5 475 //#define SPI_SCLK_Hz 4000000 // 4MHz
whismanoid 0:3edb3708c8c5 476 //#define SPI_SCLK_Hz 2000000 // 2MHz
whismanoid 0:3edb3708c8c5 477 //#define SPI_SCLK_Hz 1000000 // 1MHz
whismanoid 0:3edb3708c8c5 478 #define SPI_dataMode SPI_MODE0 // CPOL=0,CPHA=0: Falling Edge stable; SCLK idle Low
whismanoid 0:3edb3708c8c5 479 //
whismanoid 0:3edb3708c8c5 480 #elif APPLICATION_MAX12345 // SPI interface default settings
whismanoid 0:3edb3708c8c5 481 //
whismanoid 0:3edb3708c8c5 482 //#define SPI_SCLK_Hz 48000000 // 48MHz
whismanoid 0:3edb3708c8c5 483 //#define SPI_SCLK_Hz 24000000 // 24MHz
whismanoid 0:3edb3708c8c5 484 #define SPI_SCLK_Hz 12000000 // 12MHz
whismanoid 0:3edb3708c8c5 485 //#define SPI_SCLK_Hz 4000000 // 4MHz
whismanoid 0:3edb3708c8c5 486 //#define SPI_SCLK_Hz 2000000 // 2MHz
whismanoid 0:3edb3708c8c5 487 //#define SPI_SCLK_Hz 1000000 // 1MHz
whismanoid 0:3edb3708c8c5 488 #define SPI_dataMode SPI_MODE3 // CPOL=1,CPHA=1: Rising Edge stable; SCLK idle High
whismanoid 0:3edb3708c8c5 489 //
whismanoid 0:3edb3708c8c5 490 #else // APPLICATION_ArduinoPinsMonitor diagnostic
whismanoid 0:3edb3708c8c5 491 //
whismanoid 0:3edb3708c8c5 492 //#define SPI_SCLK_Hz 48000000 // 48MHz
whismanoid 0:3edb3708c8c5 493 //#define SPI_SCLK_Hz 4000000 // 4MHz
whismanoid 0:3edb3708c8c5 494 //#define SPI_SCLK_Hz 2000000 // 2MHz
whismanoid 0:3edb3708c8c5 495 #define SPI_SCLK_Hz 1000000 // 1MHz
whismanoid 0:3edb3708c8c5 496 //#define SPI_dataMode SPI_MODE0 // CPOL=0,CPHA=0: Rising Edge stable; SCLK idle Low
whismanoid 0:3edb3708c8c5 497 //#define SPI_dataMode SPI_MODE1 // CPOL=0,CPHA=1: Falling Edge stable; SCLK idle Low
whismanoid 0:3edb3708c8c5 498 //#define SPI_dataMode SPI_MODE2 // CPOL=1,CPHA=0: Falling Edge stable; SCLK idle High
whismanoid 0:3edb3708c8c5 499 #define SPI_dataMode SPI_MODE3 // CPOL=1,CPHA=1: Rising Edge stable; SCLK idle High
whismanoid 0:3edb3708c8c5 500 //
whismanoid 0:3edb3708c8c5 501 #endif
whismanoid 0:3edb3708c8c5 502 //
whismanoid 0:3edb3708c8c5 503 uint32_t g_SPI_SCLK_Hz = SPI_SCLK_Hz;
whismanoid 0:3edb3708c8c5 504 // TODO1: validate g_SPI_SCLK_Hz against system clock frequency SystemCoreClock F_CPU
whismanoid 0:3edb3708c8c5 505 #if defined(TARGET_NUCLEO_F446RE) || defined(TARGET_NUCLEO_F401RE)
whismanoid 0:3edb3708c8c5 506 // Nucleo SPI frequency isn't working quite as expected...
whismanoid 0:3edb3708c8c5 507 // Looks like STMF4 has an spi clock prescaler (2,4,8,16,32,64,128,256)
whismanoid 0:3edb3708c8c5 508 // so 180MHz->[90.0, 45.0, 22.5, 11.25, 5.625, 2.8125, 1.40625, 0.703125]
whismanoid 0:3edb3708c8c5 509 // %SC SCLK=1MHz sets spi frequency 703.125kHz
whismanoid 0:3edb3708c8c5 510 // %SC SCLK=2MHz sets spi frequency 1.40625MHz
whismanoid 0:3edb3708c8c5 511 // %SC SCLK=3MHz sets spi frequency 2.8125MHz
whismanoid 0:3edb3708c8c5 512 // %SC SCLK=6MHz sets spi frequency 5.625MHz
whismanoid 0:3edb3708c8c5 513 // %SC SCLK=12MHz sets spi frequency 11.25MHz
whismanoid 0:3edb3708c8c5 514 // %SC SCLK=23MHz sets spi frequency 22.5MHz
whismanoid 0:3edb3708c8c5 515 // %SC SCLK=45MHz sets spi frequency 45.0MHz
whismanoid 0:3edb3708c8c5 516 // Don't know why I can't reach spi frequency 90.0MHz, but ok whatever.
whismanoid 0:3edb3708c8c5 517 const uint32_t limit_min_SPI_SCLK_divisor = 2;
whismanoid 0:3edb3708c8c5 518 const uint32_t limit_max_SPI_SCLK_divisor = 256;
whismanoid 0:3edb3708c8c5 519 // not really a divisor, just a powers-of-two prescaler with no intermediate divisors.
whismanoid 0:3edb3708c8c5 520 #else
whismanoid 0:3edb3708c8c5 521 const uint32_t limit_min_SPI_SCLK_divisor = 2;
whismanoid 0:3edb3708c8c5 522 const uint32_t limit_max_SPI_SCLK_divisor = 8191;
whismanoid 0:3edb3708c8c5 523 #endif
whismanoid 0:3edb3708c8c5 524 const uint32_t limit_max_SPI_SCLK_Hz = (SystemCoreClock / limit_min_SPI_SCLK_divisor); // F_CPU / 2; // 8MHz / 2 = 4MHz
whismanoid 0:3edb3708c8c5 525 const uint32_t limit_min_SPI_SCLK_Hz = (SystemCoreClock / limit_max_SPI_SCLK_divisor); // F_CPU / 128; // 8MHz / 128 = 62.5kHz
whismanoid 0:3edb3708c8c5 526 //
whismanoid 0:3edb3708c8c5 527 uint8_t g_SPI_dataMode = SPI_dataMode;
whismanoid 0:3edb3708c8c5 528 uint8_t g_SPI_cs_state = 1;
whismanoid 0:3edb3708c8c5 529 //
whismanoid 0:3edb3708c8c5 530 #if defined(TARGET_MAX32630)
whismanoid 0:3edb3708c8c5 531 // TODO1: avoid resource conflict between P5_0, P5_1, P5_2 SPI and DigitalInOut
whismanoid 0:3edb3708c8c5 532 // void spi_init(spi_t *obj, PinName mosi, PinName miso, PinName sclk, PinName ssel)
whismanoid 0:3edb3708c8c5 533 //SPI spi0(SPI0_MOSI, SPI0_MISO, SPI0_SCK); // mosi, miso, sclk spi0 MAX32630FTHR: P0_5 P0_6 P0_4 ok but this is the microSD card, can't contact pins
whismanoid 0:3edb3708c8c5 534 //SPI spi1(SPI1_MOSI, SPI1_MISO, SPI1_SCK); // mosi, miso, sclk spi1 MAX32630FTHR: P1_1 P1_2 P1_0 ok but this is the xip flash, can't contact pins
whismanoid 0:3edb3708c8c5 535 //SPI spi2(SPI2_MOSI, SPI2_MISO, SPI2_SCK); // mosi, miso, sclk spi2 MAX32630FTHR: P5_1, P5_2, P5_0
whismanoid 0:3edb3708c8c5 536 SPI spi(SPI2_MOSI, SPI2_MISO, SPI2_SCK); // mosi, miso, sclk spi2 MAX32630FTHR: P5_1, P5_2, P5_0
whismanoid 0:3edb3708c8c5 537 //
whismanoid 0:3edb3708c8c5 538 DigitalOut spi_cs(P3_0);
whismanoid 0:3edb3708c8c5 539 #elif defined(TARGET_MAX32625MBED)
whismanoid 0:3edb3708c8c5 540 // TODO1: avoid resource conflict between P5_0, P5_1, P5_2 SPI and DigitalInOut
whismanoid 0:3edb3708c8c5 541 // void spi_init(spi_t *obj, PinName mosi, PinName miso, PinName sclk, PinName ssel)
whismanoid 0:3edb3708c8c5 542 //SPI spi(SPI0_MOSI, SPI0_MISO, SPI0_SCK); // mosi, miso, sclk spi0 TARGET_MAX32635MBED: P0_5 P0_6 P0_4 Arduino 8-pin header D5 D6 D7
whismanoid 0:3edb3708c8c5 543 //DigitalOut spi_cs(SPI0_SS); // TARGET_MAX32635MBED: P0_7 Arduino 8-pin header D4
whismanoid 0:3edb3708c8c5 544 SPI spi(SPI1_MOSI, SPI1_MISO, SPI1_SCK); // mosi, miso, sclk spi1 TARGET_MAX32635MBED: P1_1 P1_2 P1_0 Arduino 10-pin header D11 D12 D13
whismanoid 0:3edb3708c8c5 545 DigitalOut spi_cs(SPI1_SS); // TARGET_MAX32635MBED: P1_3 Arduino 10-pin header D10
whismanoid 0:3edb3708c8c5 546 SPI spi2_max541(SPI2_MOSI, SPI2_MISO, SPI2_SCK); // mosi, miso, sclk spi2 TARGET_MAX32635MBED: P2_5 P2_6 P2_4 Arduino 2x3-pin header; microSD
whismanoid 0:3edb3708c8c5 547 DigitalOut spi2_max541_cs(SPI2_SS); // TARGET_MAX32635MBED: P2_7 Arduino 2x3-pin header
whismanoid 0:3edb3708c8c5 548 #define HAS_SPI2_MAX541 1
whismanoid 0:3edb3708c8c5 549 //
whismanoid 0:3edb3708c8c5 550 #elif defined(TARGET_NUCLEO_F446RE) || defined(TARGET_NUCLEO_F401RE)
whismanoid 0:3edb3708c8c5 551 // TODO1: avoid resource conflict between P5_0, P5_1, P5_2 SPI and DigitalInOut
whismanoid 0:3edb3708c8c5 552 // void spi_init(spi_t *obj, PinName mosi, PinName miso, PinName sclk, PinName ssel)
whismanoid 0:3edb3708c8c5 553 //
whismanoid 0:3edb3708c8c5 554 // TODO1: NUCLEO_F446RE SPI not working; CS and MOSI data looks OK but no SCLK clock pulses.
whismanoid 0:3edb3708c8c5 555 SPI spi(SPI_MOSI, SPI_MISO, SPI_SCK); // mosi, miso, sclk spi1 TARGET_NUCLEO_F446RE: Arduino 10-pin header D11 D12 D13
whismanoid 0:3edb3708c8c5 556 DigitalOut spi_cs(SPI_CS); // TARGET_NUCLEO_F446RE: PB_6 Arduino 10-pin header D10
whismanoid 0:3edb3708c8c5 557 //
whismanoid 0:3edb3708c8c5 558 #elif defined(TARGET_LPC1768)
whismanoid 0:3edb3708c8c5 559 // TODO1: avoid resource conflict between P5_0, P5_1, P5_2 SPI and DigitalInOut
whismanoid 0:3edb3708c8c5 560 // void spi_init(spi_t *obj, PinName mosi, PinName miso, PinName sclk, PinName ssel)
whismanoid 0:3edb3708c8c5 561 //SPI spi0(SPI0_MOSI, SPI0_MISO, SPI0_SCK); // mosi, miso, sclk spi0 MAX32630FTHR: P0_5 P0_6 P0_4 ok but this is the microSD card, can't contact pins
whismanoid 0:3edb3708c8c5 562 //SPI spi1(SPI1_MOSI, SPI1_MISO, SPI1_SCK); // mosi, miso, sclk spi1 MAX32630FTHR: P1_1 P1_2 P1_0 ok but this is the xip flash, can't contact pins
whismanoid 0:3edb3708c8c5 563 //SPI spi2(SPI2_MOSI, SPI2_MISO, SPI2_SCK); // mosi, miso, sclk spi2 MAX32630FTHR: P5_1, P5_2, P5_0
whismanoid 0:3edb3708c8c5 564 SPI spi(SPI2_MOSI, SPI2_MISO, SPI2_SCK); // mosi, miso, sclk spi2 MAX32630FTHR: P5_1, P5_2, P5_0
whismanoid 0:3edb3708c8c5 565 //
whismanoid 0:3edb3708c8c5 566 DigitalOut spi_cs(P3_0);
whismanoid 0:3edb3708c8c5 567 #else
whismanoid 0:3edb3708c8c5 568 // unknown target
whismanoid 0:3edb3708c8c5 569 #endif
whismanoid 0:3edb3708c8c5 570 #endif
whismanoid 0:3edb3708c8c5 571
whismanoid 0:3edb3708c8c5 572 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 573 // Device driver object
whismanoid 0:3edb3708c8c5 574 #if APPLICATION_MAX5715 // SPI interface default settings
whismanoid 0:3edb3708c8c5 575 DigitalOut LDACb_pin(D9); // Arduino 10-pin header D9
whismanoid 0:3edb3708c8c5 576 DigitalOut CLRb_pin(D8); // Arduino 10-pin header D8
whismanoid 0:3edb3708c8c5 577 //~ DigitalIn RDYb_pin(D12); // Arduino 10-pin header D12 (MISO)
whismanoid 0:3edb3708c8c5 578 MAX5715 g_MAX5715_device(spi, spi_cs,
whismanoid 0:3edb3708c8c5 579 LDACb_pin,
whismanoid 0:3edb3708c8c5 580 CLRb_pin,
whismanoid 0:3edb3708c8c5 581 ///* RDYb_pin */ digitalInOut12,
whismanoid 0:3edb3708c8c5 582 MAX5715::MAX5715_IC);
whismanoid 0:3edb3708c8c5 583 //
whismanoid 0:3edb3708c8c5 584 #elif APPLICATION_MAX11131 // SPI interface default settings
whismanoid 0:3edb3708c8c5 585 DigitalOut CNVSTb_pin(D9); // Arduino 10-pin header D9
whismanoid 0:3edb3708c8c5 586 //DigitalOut CLRb_pin(D8); // Arduino 10-pin header D8
whismanoid 0:3edb3708c8c5 587 DigitalIn EOCb_pin(D12); // Arduino 10-pin header D12 (MISO)
whismanoid 0:3edb3708c8c5 588 MAX11131 g_MAX11131_device(spi, spi_cs,
whismanoid 0:3edb3708c8c5 589 CNVSTb_pin,
whismanoid 0:3edb3708c8c5 590 EOCb_pin,
whismanoid 0:3edb3708c8c5 591 ///* RDYb_pin */ digitalInOut12,
whismanoid 0:3edb3708c8c5 592 MAX11131::MAX11131_IC);
whismanoid 0:3edb3708c8c5 593 //
whismanoid 0:3edb3708c8c5 594 //
whismanoid 0:3edb3708c8c5 595 #elif APPLICATION_MAX5171 // SPI interface default settings
whismanoid 0:3edb3708c8c5 596 // AnalogOut FB_pin(Px_x_PortName_To_Be_Determined); // Analog Input to MAX5171 device
whismanoid 0:3edb3708c8c5 597 DigitalOut RS_pin(D9); // Digital Configuration Input to MAX5171 device
whismanoid 0:3edb3708c8c5 598 DigitalOut PDLb_pin(D8); // Digital Configuration Input to MAX5171 device
whismanoid 0:3edb3708c8c5 599 DigitalOut CLRb_pin(D7); // Digital Configuration Input to MAX5171 device
whismanoid 0:3edb3708c8c5 600 DigitalOut SHDN_pin(D6); // Digital Configuration Input to MAX5171 device
whismanoid 0:3edb3708c8c5 601 // AnalogIn OUT_pin(A0); // Analog Output from MAX5171 device
whismanoid 0:3edb3708c8c5 602 DigitalIn UPO_pin(D2); // Digital General-Purpose Output from MAX5171 device
whismanoid 0:3edb3708c8c5 603 MAX5171 g_MAX5171_device(spi, spi_cs, RS_pin, PDLb_pin, CLRb_pin, SHDN_pin, UPO_pin, MAX5171::MAX5171_IC);
whismanoid 0:3edb3708c8c5 604 //
whismanoid 0:3edb3708c8c5 605 #elif APPLICATION_MAX11410 // SPI interface default settings
whismanoid 0:3edb3708c8c5 606 //
whismanoid 0:3edb3708c8c5 607 MAX11410 g_MAX11410_device(spi, spi_cs, MAX11410::MAX11410_IC);
whismanoid 0:3edb3708c8c5 608 //
whismanoid 0:3edb3708c8c5 609 #elif APPLICATION_MAX12345 // SPI interface default settings
whismanoid 0:3edb3708c8c5 610 //
whismanoid 0:3edb3708c8c5 611 MAX12345 g_MAX12345_device(spi, spi_cs, ...);
whismanoid 0:3edb3708c8c5 612 //
whismanoid 0:3edb3708c8c5 613 #else // APPLICATION_ArduinoPinsMonitor diagnostic
whismanoid 0:3edb3708c8c5 614 //
whismanoid 0:3edb3708c8c5 615 #endif
whismanoid 0:3edb3708c8c5 616
whismanoid 0:3edb3708c8c5 617
whismanoid 0:3edb3708c8c5 618 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 619 // Option to dedicate I2C port pins
whismanoid 0:3edb3708c8c5 620 //
whismanoid 0:3edb3708c8c5 621 #ifndef HAS_I2C
whismanoid 0:3edb3708c8c5 622 #define HAS_I2C 1
whismanoid 0:3edb3708c8c5 623 #endif
whismanoid 0:3edb3708c8c5 624 #if HAS_I2C
whismanoid 0:3edb3708c8c5 625 //#include "I2C.h"
whismanoid 0:3edb3708c8c5 626 //#include "I2CSlave.h"
whismanoid 0:3edb3708c8c5 627 //#define I2C_SCL_Hz 400000 // 400kHz
whismanoid 0:3edb3708c8c5 628 //#define I2C_SCL_Hz 200000 // 200kHz
whismanoid 0:3edb3708c8c5 629 #define I2C_SCL_Hz 100000 // 100kHz
whismanoid 0:3edb3708c8c5 630 //
whismanoid 0:3edb3708c8c5 631 #if defined(TARGET_MAX32630)
whismanoid 0:3edb3708c8c5 632 // TODO1: validate g_I2C_SCL_Hz against system clock frequency SystemCoreClock F_CPU
whismanoid 0:3edb3708c8c5 633 const uint32_t limit_max_I2C_SCL_Hz = (SystemCoreClock / 2); // F_CPU / 2; // 8MHz / 2 = 4MHz
whismanoid 0:3edb3708c8c5 634 const uint32_t limit_min_I2C_SCL_Hz = (SystemCoreClock / 8191); // F_CPU / 128; // 8MHz / 128 = 62.5kHz
whismanoid 0:3edb3708c8c5 635 //
whismanoid 0:3edb3708c8c5 636 // avoid resource conflict between P5_7, P6_0 I2C and DigitalInOut
whismanoid 0:3edb3708c8c5 637 //I2C i2cMaster0(I2C0_SDA, I2C0_SCL); // sda scl MAX32630FTHR: NOT_CONNECTED
whismanoid 0:3edb3708c8c5 638 //I2C i2cMaster1(I2C1_SDA, I2C1_SCL); // sda scl MAX32630FTHR: P3_4, P3_5
whismanoid 0:3edb3708c8c5 639 //I2C i2cMaster2(I2C2_SDA, I2C2_SCL); // sda scl MAX32630FTHR: P5_7, P6_0
whismanoid 0:3edb3708c8c5 640 //I2C i2cMaster(I2C2_SDA, I2C2_SCL); // sda scl MAX32630FTHR: P5_7, P6_0
whismanoid 0:3edb3708c8c5 641 //
whismanoid 0:3edb3708c8c5 642 //I2CSlave i2cSlave0(I2C0_SDA, I2C0_SCL); // sda scl MAX32630FTHR: NOT_CONNECTED
whismanoid 0:3edb3708c8c5 643 //I2CSlave i2cSlave1(I2C1_SDA, I2C1_SCL); // sda scl MAX32630FTHR: P3_4, P3_5
whismanoid 0:3edb3708c8c5 644 //I2CSlave i2cSlave2(I2C2_SDA, I2C2_SCL); // sda scl MAX32630FTHR: P5_7, P6_0
whismanoid 0:3edb3708c8c5 645 #elif defined(TARGET_MAX32625MBED)
whismanoid 0:3edb3708c8c5 646 // TODO1: validate g_I2C_SCL_Hz against system clock frequency SystemCoreClock F_CPU
whismanoid 0:3edb3708c8c5 647 const uint32_t limit_max_I2C_SCL_Hz = (SystemCoreClock / 2); // F_CPU / 2; // 8MHz / 2 = 4MHz
whismanoid 0:3edb3708c8c5 648 const uint32_t limit_min_I2C_SCL_Hz = (SystemCoreClock / 8191); // F_CPU / 128; // 8MHz / 128 = 62.5kHz
whismanoid 0:3edb3708c8c5 649 //
whismanoid 0:3edb3708c8c5 650 // avoid resource conflict between P5_7, P6_0 I2C and DigitalInOut
whismanoid 0:3edb3708c8c5 651 //I2C i2cMaster0(I2C0_SDA, I2C0_SCL); // sda scl TARGET_MAX32635MBED: P1_6, P1_7 Arduino 10-pin header
whismanoid 0:3edb3708c8c5 652 //I2C i2cMaster1(I2C1_SDA, I2C1_SCL); // sda scl TARGET_MAX32635MBED: P3_4, P3_5 Arduino 6-pin header
whismanoid 0:3edb3708c8c5 653 // declare in narrower scope: MAX32625MBED I2C i2cMaster(I2C0_SDA, I2C0_SCL); // sda scl TARGET_MAX32635MBED: P1_6, P1_7 Arduino 10-pin header
whismanoid 0:3edb3708c8c5 654 //
whismanoid 0:3edb3708c8c5 655 #elif defined(TARGET_NUCLEO_F446RE)
whismanoid 0:3edb3708c8c5 656 // TODO1: validate g_I2C_SCL_Hz against system clock frequency SystemCoreClock F_CPU
whismanoid 0:3edb3708c8c5 657 const uint32_t limit_max_I2C_SCL_Hz = (SystemCoreClock / 2); // F_CPU / 2; // 8MHz / 2 = 4MHz
whismanoid 0:3edb3708c8c5 658 const uint32_t limit_min_I2C_SCL_Hz = (SystemCoreClock / 8191); // F_CPU / 128; // 8MHz / 128 = 62.5kHz
whismanoid 0:3edb3708c8c5 659 //
whismanoid 0:3edb3708c8c5 660 // avoid resource conflict between P5_7, P6_0 I2C and DigitalInOut
whismanoid 0:3edb3708c8c5 661 //I2C i2cMaster0(I2C0_SDA, I2C0_SCL); // sda scl TARGET_MAX32635MBED: P1_6, P1_7 Arduino 10-pin header
whismanoid 0:3edb3708c8c5 662 //I2C i2cMaster1(I2C1_SDA, I2C1_SCL); // sda scl TARGET_MAX32635MBED: P3_4, P3_5 Arduino 6-pin header
whismanoid 0:3edb3708c8c5 663 // declare in narrower scope: MAX32625MBED I2C i2cMaster(I2C0_SDA, I2C0_SCL); // sda scl TARGET_MAX32635MBED: P1_6, P1_7 Arduino 10-pin header
whismanoid 0:3edb3708c8c5 664 # ifndef I2C0_SDA
whismanoid 0:3edb3708c8c5 665 # define I2C0_SDA I2C_SDA
whismanoid 0:3edb3708c8c5 666 # define I2C0_SCL I2C_SCL
whismanoid 0:3edb3708c8c5 667 # endif
whismanoid 0:3edb3708c8c5 668 //
whismanoid 0:3edb3708c8c5 669 #elif defined(TARGET_NUCLEO_F401RE)
whismanoid 0:3edb3708c8c5 670 // TODO1: validate g_I2C_SCL_Hz against system clock frequency SystemCoreClock F_CPU
whismanoid 0:3edb3708c8c5 671 const uint32_t limit_max_I2C_SCL_Hz = (SystemCoreClock / 2); // F_CPU / 2; // 8MHz / 2 = 4MHz
whismanoid 0:3edb3708c8c5 672 const uint32_t limit_min_I2C_SCL_Hz = (SystemCoreClock / 8191); // F_CPU / 128; // 8MHz / 128 = 62.5kHz
whismanoid 0:3edb3708c8c5 673 //
whismanoid 0:3edb3708c8c5 674 // avoid resource conflict between P5_7, P6_0 I2C and DigitalInOut
whismanoid 0:3edb3708c8c5 675 //I2C i2cMaster0(I2C0_SDA, I2C0_SCL); // sda scl TARGET_MAX32635MBED: P1_6, P1_7 Arduino 10-pin header
whismanoid 0:3edb3708c8c5 676 //I2C i2cMaster1(I2C1_SDA, I2C1_SCL); // sda scl TARGET_MAX32635MBED: P3_4, P3_5 Arduino 6-pin header
whismanoid 0:3edb3708c8c5 677 // declare in narrower scope: MAX32625MBED I2C i2cMaster(I2C0_SDA, I2C0_SCL); // sda scl TARGET_MAX32635MBED: P1_6, P1_7 Arduino 10-pin header
whismanoid 0:3edb3708c8c5 678 # ifndef I2C0_SDA
whismanoid 0:3edb3708c8c5 679 # define I2C0_SDA I2C_SDA
whismanoid 0:3edb3708c8c5 680 # define I2C0_SCL I2C_SCL
whismanoid 0:3edb3708c8c5 681 # endif
whismanoid 0:3edb3708c8c5 682 //
whismanoid 0:3edb3708c8c5 683 #elif defined(TARGET_LPC1768)
whismanoid 0:3edb3708c8c5 684 #else
whismanoid 0:3edb3708c8c5 685 // unknown target
whismanoid 0:3edb3708c8c5 686 #endif
whismanoid 0:3edb3708c8c5 687 //
whismanoid 0:3edb3708c8c5 688 #endif
whismanoid 0:3edb3708c8c5 689 #if HAS_I2C
whismanoid 0:3edb3708c8c5 690 uint32_t g_I2C_SCL_Hz = I2C_SCL_Hz;
whismanoid 0:3edb3708c8c5 691 uint8_t g_I2C_status = 0; // g_I2C_status = Wire_Sr.endTransmission();
whismanoid 0:3edb3708c8c5 692 uint8_t g_I2C_deviceAddress7 = (0xA0 >> 1); // I2C device address (slave address on I2C bus), 7-bits, RIGHT-justified.
whismanoid 0:3edb3708c8c5 693 uint8_t g_I2C_read_count = 0;
whismanoid 0:3edb3708c8c5 694 uint8_t g_I2C_write_count = 0;
whismanoid 0:3edb3708c8c5 695 uint8_t g_I2C_write_data[256];
whismanoid 0:3edb3708c8c5 696 uint8_t g_I2C_command_regAddress;
whismanoid 0:3edb3708c8c5 697 //
whismanoid 0:3edb3708c8c5 698 // TODO: i2c init
whismanoid 0:3edb3708c8c5 699 // i2cMaster.frequency(g_I2C_SCL_Hz);
whismanoid 0:3edb3708c8c5 700 #endif
whismanoid 0:3edb3708c8c5 701 #if HAS_I2C
whismanoid 0:3edb3708c8c5 702 // TODO: i2c transfer
whismanoid 0:3edb3708c8c5 703 //const int addr7bit = 0x48; // 7 bit I2C address
whismanoid 0:3edb3708c8c5 704 //const int addr8bit = 0x48 << 1; // 8bit I2C address, 0x90
whismanoid 0:3edb3708c8c5 705 // /* int */ i2cMaster.read (int addr8bit, char *data, int length, bool repeated=false) // Read from an I2C slave.
whismanoid 0:3edb3708c8c5 706 // /* int */ i2cMaster.read (int ack) // Read a single byte from the I2C bus.
whismanoid 0:3edb3708c8c5 707 // /* int */ i2cMaster.write (int addr8bit, const char *data, int length, bool repeated=false) // Write to an I2C slave.
whismanoid 0:3edb3708c8c5 708 // /* int */ i2cMaster.write (int data) // Write single byte out on the I2C bus.
whismanoid 0:3edb3708c8c5 709 // /* void */ i2cMaster.start (void) // Creates a start condition on the I2C bus.
whismanoid 0:3edb3708c8c5 710 // /* void */ i2cMaster.stop (void) // Creates a stop condition on the I2C bus.
whismanoid 0:3edb3708c8c5 711 // /* int */ i2cMaster.transfer (int addr8bit, const char *tx_buffer, int tx_length, char *rx_buffer, int rx_length, const event_callback_t &callback, int event=I2C_EVENT_TRANSFER_COMPLETE, bool repeated=false) // Start nonblocking I2C transfer. More...
whismanoid 0:3edb3708c8c5 712 // /* void */ i2cMaster.abort_transfer () // Abort the ongoing I2C transfer. More...
whismanoid 0:3edb3708c8c5 713 #endif
whismanoid 0:3edb3708c8c5 714
whismanoid 0:3edb3708c8c5 715
whismanoid 0:3edb3708c8c5 716 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 717 // Declare the Serial driver
whismanoid 0:3edb3708c8c5 718 // default baud rate settings are 9600 8N1
whismanoid 0:3edb3708c8c5 719 // install device driver from http://developer.mbed.org/media/downloads/drivers/mbedWinSerial_16466.exe
whismanoid 0:3edb3708c8c5 720 // see docs https://docs.mbed.com/docs/mbed-os-handbook/en/5.5/getting_started/what_need/
whismanoid 0:3edb3708c8c5 721 #if defined(TARGET_MAX32630)
whismanoid 0:3edb3708c8c5 722 #include "USBSerial.h"
whismanoid 0:3edb3708c8c5 723 // Hardware serial port over DAPLink
whismanoid 0:3edb3708c8c5 724 // The default baud rate for the DapLink UART is 9600
whismanoid 0:3edb3708c8c5 725 Serial DAPLINKserial(P2_1, P2_0); // tx, rx
whismanoid 0:3edb3708c8c5 726 #define HAS_DAPLINK_SERIAL 1
whismanoid 0:3edb3708c8c5 727 // Virtual serial port over USB
whismanoid 0:3edb3708c8c5 728 // The baud rate does not affect the virtual USBSerial UART.
whismanoid 0:3edb3708c8c5 729 USBSerial microUSBserial;
whismanoid 0:3edb3708c8c5 730 #define HAS_MICROUSBSERIAL 1
whismanoid 0:3edb3708c8c5 731 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 732 #elif defined(TARGET_MAX32625MBED)
whismanoid 0:3edb3708c8c5 733 #include "USBSerial.h"
whismanoid 0:3edb3708c8c5 734 // Hardware serial port over DAPLink
whismanoid 0:3edb3708c8c5 735 // The default baud rate for the DapLink UART is 9600
whismanoid 0:3edb3708c8c5 736 Serial DAPLINKserial(P2_1, P2_0); // tx, rx
whismanoid 0:3edb3708c8c5 737 #define HAS_DAPLINK_SERIAL 1
whismanoid 0:3edb3708c8c5 738 // Virtual serial port over USB
whismanoid 0:3edb3708c8c5 739 // The baud rate does not affect the virtual USBSerial UART.
whismanoid 0:3edb3708c8c5 740 USBSerial microUSBserial;
whismanoid 0:3edb3708c8c5 741 #define HAS_MICROUSBSERIAL 1
whismanoid 0:3edb3708c8c5 742 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 743 #elif defined(TARGET_NUCLEO_F446RE) || defined(TARGET_NUCLEO_F401RE)
whismanoid 0:3edb3708c8c5 744 Serial microUSBserial(SERIAL_TX, SERIAL_RX); // tx, rx
whismanoid 0:3edb3708c8c5 745 #define HAS_MICROUSBSERIAL 1
whismanoid 0:3edb3708c8c5 746 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 747 // TODO1: TARGET=MAX32625MBED ARM Cortex-M4F 96MHz 512kB Flash 160kB SRAM
whismanoid 0:3edb3708c8c5 748 #elif defined(TARGET_LPC1768)
whismanoid 0:3edb3708c8c5 749 Serial microUSBserial(USBTX, USBRX); // tx, rx
whismanoid 0:3edb3708c8c5 750 #define HAS_MICROUSBSERIAL 1
whismanoid 0:3edb3708c8c5 751 #else
whismanoid 0:3edb3708c8c5 752 // unknown target
whismanoid 0:3edb3708c8c5 753 #endif
whismanoid 0:3edb3708c8c5 754
whismanoid 0:3edb3708c8c5 755 void on_immediate_0x21(); // Unicode (U+0021) ! EXCLAMATION MARK
whismanoid 0:3edb3708c8c5 756 void on_immediate_0x7b(); // Unicode (U+007B) { LEFT CURLY BRACKET
whismanoid 0:3edb3708c8c5 757 void on_immediate_0x7d(); // Unicode (U+007D) } RIGHT CURLY BRACKET
whismanoid 0:3edb3708c8c5 758
whismanoid 0:3edb3708c8c5 759 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 760 // Option to process command buffer from microUSBserial or DAPLINKserial
whismanoid 0:3edb3708c8c5 761 #ifndef USE_COMMAND_BUFFER
whismanoid 0:3edb3708c8c5 762 #define USE_COMMAND_BUFFER 1
whismanoid 0:3edb3708c8c5 763 #endif
whismanoid 0:3edb3708c8c5 764 #if USE_COMMAND_BUFFER
whismanoid 0:3edb3708c8c5 765 #include "CmdLine.h"
whismanoid 0:3edb3708c8c5 766
whismanoid 0:3edb3708c8c5 767 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 768 CmdLine cmdLine_DAPLINKserial(DAPLINKserial, "DAPLINK");
whismanoid 0:3edb3708c8c5 769 # endif // HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 770 // TODO1: diagnostic: define HAS_MICROUSBSERIAL 0
whismanoid 0:3edb3708c8c5 771 //~ #define HAS_MICROUSBSERIAL 0
whismanoid 0:3edb3708c8c5 772 # if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 773 CmdLine cmdLine_microUSBserial(microUSBserial, "microUSB");
whismanoid 0:3edb3708c8c5 774 # endif // HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 775
whismanoid 0:3edb3708c8c5 776 #endif // USE_COMMAND_BUFFER
whismanoid 0:3edb3708c8c5 777
whismanoid 0:3edb3708c8c5 778 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 779 // tolerate AT commands, which may be sent during probe, such as:
whismanoid 0:3edb3708c8c5 780 // AT
whismanoid 0:3edb3708c8c5 781 // AT+CGMI -- request manufacturer identification AT+CMGI=?
whismanoid 0:3edb3708c8c5 782 // AT+CGMM -- request manufacturer model
whismanoid 0:3edb3708c8c5 783 // AT%IPSYS?
whismanoid 0:3edb3708c8c5 784 // ATE0 -- echo disable
whismanoid 0:3edb3708c8c5 785 // ATV1 -- verbose result codes OK | ERROR | NO CARRIER
whismanoid 0:3edb3708c8c5 786 // AT+CMEE=1
whismanoid 0:3edb3708c8c5 787 // ATX4
whismanoid 0:3edb3708c8c5 788 // AT&C1
whismanoid 0:3edb3708c8c5 789 // ATE0
whismanoid 0:3edb3708c8c5 790 // AT+CMEE=1
whismanoid 0:3edb3708c8c5 791 // AT+GCAP
whismanoid 0:3edb3708c8c5 792 // ATI
whismanoid 0:3edb3708c8c5 793 // AT+CPIN?
whismanoid 0:3edb3708c8c5 794 // AT+CGMM
whismanoid 0:3edb3708c8c5 795 #ifndef IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 796 #define IGNORE_AT_COMMANDS 1
whismanoid 0:3edb3708c8c5 797 #endif
whismanoid 0:3edb3708c8c5 798
whismanoid 0:3edb3708c8c5 799
whismanoid 0:3edb3708c8c5 800 // uncrustify-0.66.1 *INDENT-OFF*
whismanoid 0:3edb3708c8c5 801 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 802 // Declare the DigitalInOut GPIO pins
whismanoid 0:3edb3708c8c5 803 // Optional digitalInOut support. If there is only one it should be digitalInOut1.
whismanoid 0:3edb3708c8c5 804 // D) Digital High/Low/Input Pin
whismanoid 0:3edb3708c8c5 805 #if defined(TARGET_MAX32630)
whismanoid 0:3edb3708c8c5 806 // +-------------[microUSB]-------------+
whismanoid 0:3edb3708c8c5 807 // | J1 MAX32630FTHR J2 |
whismanoid 0:3edb3708c8c5 808 // | [ ] RST GND [ ] |
whismanoid 0:3edb3708c8c5 809 // | [ ] 3V3 BAT+[ ] |
whismanoid 0:3edb3708c8c5 810 // | [ ] 1V8 reset SW1 |
whismanoid 0:3edb3708c8c5 811 // | [ ] GND J4 J3 |
whismanoid 0:3edb3708c8c5 812 // | [ ] AIN_0 1.2Vfs (bat) SYS [ ] |
whismanoid 0:3edb3708c8c5 813 // | [ ] AIN_1 1.2Vfs PWR [ ] |
whismanoid 0:3edb3708c8c5 814 // | [ ] AIN_2 1.2Vfs +5V VBUS [ ] |
whismanoid 0:3edb3708c8c5 815 // | [ ] AIN_3 1.2Vfs 1-WIRE P4_0 [ ] | dig9
whismanoid 0:3edb3708c8c5 816 // dig10 | [x] P5_7 SDA2 SRN P5_6 [ ] | dig8
whismanoid 0:3edb3708c8c5 817 // dig11 | [x] P6_0 SCL2 SDIO3 P5_5 [ ] | dig7
whismanoid 0:3edb3708c8c5 818 // dig12 | [x] P5_0 SCLK SDIO2 P5_4 [ ] | dig6
whismanoid 0:3edb3708c8c5 819 // dig13 | [x] P5_1 MOSI SSEL P5_3 [x] | dig5
whismanoid 0:3edb3708c8c5 820 // dig14 | [ ] P5_2 MISO RTS P3_3 [ ] | dig4
whismanoid 0:3edb3708c8c5 821 // dig15 | [ ] P3_0 RX CTS P3_2 [ ] | dig3
whismanoid 0:3edb3708c8c5 822 // dig0 | [ ] P3_1 TX SCL P3_5 [x] | dig2
whismanoid 0:3edb3708c8c5 823 // | [ ] GND SDA P3_4 [x] | dig1
whismanoid 0:3edb3708c8c5 824 // +------------------------------------+
whismanoid 0:3edb3708c8c5 825 #define HAS_digitalInOut0 1 // P3_1 TARGET_MAX32630 J1.15
whismanoid 0:3edb3708c8c5 826 #define HAS_digitalInOut1 1 // P3_4 TARGET_MAX32630 J3.12
whismanoid 0:3edb3708c8c5 827 #define HAS_digitalInOut2 1 // P3_5 TARGET_MAX32630 J3.11
whismanoid 0:3edb3708c8c5 828 #define HAS_digitalInOut3 1 // P3_2 TARGET_MAX32630 J3.10
whismanoid 0:3edb3708c8c5 829 #define HAS_digitalInOut4 1 // P3_3 TARGET_MAX32630 J3.9
whismanoid 0:3edb3708c8c5 830 #define HAS_digitalInOut5 1 // P5_3 TARGET_MAX32630 J3.8
whismanoid 0:3edb3708c8c5 831 #define HAS_digitalInOut6 1 // P5_4 TARGET_MAX32630 J3.7
whismanoid 0:3edb3708c8c5 832 #define HAS_digitalInOut7 1 // P5_5 TARGET_MAX32630 J3.6
whismanoid 0:3edb3708c8c5 833 #define HAS_digitalInOut8 1 // P5_6 TARGET_MAX32630 J3.5
whismanoid 0:3edb3708c8c5 834 #define HAS_digitalInOut9 1 // P4_0 TARGET_MAX32630 J3.4
whismanoid 0:3edb3708c8c5 835 #if HAS_I2C
whismanoid 0:3edb3708c8c5 836 // avoid resource conflict between P5_7, P6_0 I2C and DigitalInOut
whismanoid 0:3edb3708c8c5 837 #define HAS_digitalInOut10 0 // P5_7 TARGET_MAX32630 J1.9
whismanoid 0:3edb3708c8c5 838 #define HAS_digitalInOut11 0 // P6_0 TARGET_MAX32630 J1.10
whismanoid 0:3edb3708c8c5 839 #else // HAS_I2C
whismanoid 0:3edb3708c8c5 840 #define HAS_digitalInOut10 1 // P5_7 TARGET_MAX32630 J1.9
whismanoid 0:3edb3708c8c5 841 #define HAS_digitalInOut11 1 // P6_0 TARGET_MAX32630 J1.10
whismanoid 0:3edb3708c8c5 842 #endif // HAS_I2C
whismanoid 0:3edb3708c8c5 843 #if HAS_SPI
whismanoid 0:3edb3708c8c5 844 // avoid resource conflict between P5_0, P5_1, P5_2 SPI and DigitalInOut
whismanoid 0:3edb3708c8c5 845 #define HAS_digitalInOut12 0 // P5_0 TARGET_MAX32630 J1.11
whismanoid 0:3edb3708c8c5 846 #define HAS_digitalInOut13 0 // P5_1 TARGET_MAX32630 J1.12
whismanoid 0:3edb3708c8c5 847 #define HAS_digitalInOut14 0 // P5_2 TARGET_MAX32630 J1.13
whismanoid 0:3edb3708c8c5 848 #define HAS_digitalInOut15 0 // P3_0 TARGET_MAX32630 J1.14
whismanoid 0:3edb3708c8c5 849 #else // HAS_SPI
whismanoid 0:3edb3708c8c5 850 #define HAS_digitalInOut12 1 // P5_0 TARGET_MAX32630 J1.11
whismanoid 0:3edb3708c8c5 851 #define HAS_digitalInOut13 1 // P5_1 TARGET_MAX32630 J1.12
whismanoid 0:3edb3708c8c5 852 #define HAS_digitalInOut14 1 // P5_2 TARGET_MAX32630 J1.13
whismanoid 0:3edb3708c8c5 853 #define HAS_digitalInOut15 1 // P3_0 TARGET_MAX32630 J1.14
whismanoid 0:3edb3708c8c5 854 #endif // HAS_SPI
whismanoid 0:3edb3708c8c5 855 #if HAS_digitalInOut0
whismanoid 0:3edb3708c8c5 856 DigitalInOut digitalInOut0(P3_1, PIN_INPUT, PullUp, 1); // P3_1 TARGET_MAX32630 J1.15
whismanoid 0:3edb3708c8c5 857 #endif
whismanoid 0:3edb3708c8c5 858 #if HAS_digitalInOut1
whismanoid 0:3edb3708c8c5 859 DigitalInOut digitalInOut1(P3_4, PIN_INPUT, PullUp, 1); // P3_4 TARGET_MAX32630 J3.12
whismanoid 0:3edb3708c8c5 860 #endif
whismanoid 0:3edb3708c8c5 861 #if HAS_digitalInOut2
whismanoid 0:3edb3708c8c5 862 DigitalInOut digitalInOut2(P3_5, PIN_INPUT, PullUp, 1); // P3_5 TARGET_MAX32630 J3.11
whismanoid 0:3edb3708c8c5 863 #endif
whismanoid 0:3edb3708c8c5 864 #if HAS_digitalInOut3
whismanoid 0:3edb3708c8c5 865 DigitalInOut digitalInOut3(P3_2, PIN_INPUT, PullUp, 1); // P3_2 TARGET_MAX32630 J3.10
whismanoid 0:3edb3708c8c5 866 #endif
whismanoid 0:3edb3708c8c5 867 #if HAS_digitalInOut4
whismanoid 0:3edb3708c8c5 868 DigitalInOut digitalInOut4(P3_3, PIN_INPUT, PullUp, 1); // P3_3 TARGET_MAX32630 J3.9
whismanoid 0:3edb3708c8c5 869 #endif
whismanoid 0:3edb3708c8c5 870 #if HAS_digitalInOut5
whismanoid 0:3edb3708c8c5 871 DigitalInOut digitalInOut5(P5_3, PIN_INPUT, PullUp, 1); // P5_3 TARGET_MAX32630 J3.8
whismanoid 0:3edb3708c8c5 872 #endif
whismanoid 0:3edb3708c8c5 873 #if HAS_digitalInOut6
whismanoid 0:3edb3708c8c5 874 DigitalInOut digitalInOut6(P5_4, PIN_INPUT, PullUp, 1); // P5_4 TARGET_MAX32630 J3.7
whismanoid 0:3edb3708c8c5 875 #endif
whismanoid 0:3edb3708c8c5 876 #if HAS_digitalInOut7
whismanoid 0:3edb3708c8c5 877 DigitalInOut digitalInOut7(P5_5, PIN_INPUT, PullUp, 1); // P5_5 TARGET_MAX32630 J3.6
whismanoid 0:3edb3708c8c5 878 #endif
whismanoid 0:3edb3708c8c5 879 #if HAS_digitalInOut8
whismanoid 0:3edb3708c8c5 880 DigitalInOut digitalInOut8(P5_6, PIN_INPUT, PullUp, 1); // P5_6 TARGET_MAX32630 J3.5
whismanoid 0:3edb3708c8c5 881 #endif
whismanoid 0:3edb3708c8c5 882 #if HAS_digitalInOut9
whismanoid 0:3edb3708c8c5 883 DigitalInOut digitalInOut9(P4_0, PIN_INPUT, PullUp, 1); // P4_0 TARGET_MAX32630 J3.4
whismanoid 0:3edb3708c8c5 884 #endif
whismanoid 0:3edb3708c8c5 885 #if HAS_digitalInOut10
whismanoid 0:3edb3708c8c5 886 DigitalInOut digitalInOut10(P5_7, PIN_INPUT, PullUp, 1); // P5_7 TARGET_MAX32630 J1.9
whismanoid 0:3edb3708c8c5 887 #endif
whismanoid 0:3edb3708c8c5 888 #if HAS_digitalInOut11
whismanoid 0:3edb3708c8c5 889 DigitalInOut digitalInOut11(P6_0, PIN_INPUT, PullUp, 1); // P6_0 TARGET_MAX32630 J1.10
whismanoid 0:3edb3708c8c5 890 #endif
whismanoid 0:3edb3708c8c5 891 #if HAS_digitalInOut12
whismanoid 0:3edb3708c8c5 892 DigitalInOut digitalInOut12(P5_0, PIN_INPUT, PullUp, 1); // P5_0 TARGET_MAX32630 J1.11
whismanoid 0:3edb3708c8c5 893 #endif
whismanoid 0:3edb3708c8c5 894 #if HAS_digitalInOut13
whismanoid 0:3edb3708c8c5 895 DigitalInOut digitalInOut13(P5_1, PIN_INPUT, PullUp, 1); // P5_1 TARGET_MAX32630 J1.12
whismanoid 0:3edb3708c8c5 896 #endif
whismanoid 0:3edb3708c8c5 897 #if HAS_digitalInOut14
whismanoid 0:3edb3708c8c5 898 DigitalInOut digitalInOut14(P5_2, PIN_INPUT, PullUp, 1); // P5_2 TARGET_MAX32630 J1.13
whismanoid 0:3edb3708c8c5 899 #endif
whismanoid 0:3edb3708c8c5 900 #if HAS_digitalInOut15
whismanoid 0:3edb3708c8c5 901 DigitalInOut digitalInOut15(P3_0, PIN_INPUT, PullUp, 1); // P3_0 TARGET_MAX32630 J1.14
whismanoid 0:3edb3708c8c5 902 #endif
whismanoid 0:3edb3708c8c5 903 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 904 #elif defined(TARGET_MAX32625MBED)
whismanoid 0:3edb3708c8c5 905 // TARGET=MAX32625MBED ARM Cortex-M4F 96MHz 512kB Flash 160kB SRAM
whismanoid 0:3edb3708c8c5 906 // +-------------------------------------+
whismanoid 0:3edb3708c8c5 907 // | MAX32625MBED Arduino UNO header |
whismanoid 0:3edb3708c8c5 908 // | |
whismanoid 0:3edb3708c8c5 909 // | A5/SCL[ ] | P1_7 dig15
whismanoid 0:3edb3708c8c5 910 // | A4/SDA[ ] | P1_6 dig14
whismanoid 0:3edb3708c8c5 911 // | AREF=N/C[ ] |
whismanoid 0:3edb3708c8c5 912 // | GND[ ] |
whismanoid 0:3edb3708c8c5 913 // | [ ]N/C SCK/13[ ] | P1_0 dig13
whismanoid 0:3edb3708c8c5 914 // | [ ]IOREF=3V3 MISO/12[ ] | P1_2 dig12
whismanoid 0:3edb3708c8c5 915 // | [ ]RST MOSI/11[ ]~| P1_1 dig11
whismanoid 0:3edb3708c8c5 916 // | [ ]3V3 CS/10[ ]~| P1_3 dig10
whismanoid 0:3edb3708c8c5 917 // | [ ]5V0 9[ ]~| P1_5 dig9
whismanoid 0:3edb3708c8c5 918 // | [ ]GND 8[ ] | P1_4 dig8
whismanoid 0:3edb3708c8c5 919 // | [ ]GND |
whismanoid 0:3edb3708c8c5 920 // | [ ]Vin 7[ ] | P0_7 dig7
whismanoid 0:3edb3708c8c5 921 // | 6[ ]~| P0_6 dig6
whismanoid 0:3edb3708c8c5 922 // AIN_0 | [ ]A0 5[ ]~| P0_5 dig5
whismanoid 0:3edb3708c8c5 923 // AIN_1 | [ ]A1 4[ ] | P0_4 dig4
whismanoid 0:3edb3708c8c5 924 // AIN_2 | [ ]A2 INT1/3[ ]~| P0_3 dig3
whismanoid 0:3edb3708c8c5 925 // AIN_3 | [ ]A3 INT0/2[ ] | P0_2 dig2
whismanoid 0:3edb3708c8c5 926 // dig16 P3_4 | [ ]A4/SDA RST SCK MISO TX>1[ ] | P0_1 dig1
whismanoid 0:3edb3708c8c5 927 // dig17 P3_5 | [ ]A5/SCL [ ] [ ] [ ] RX<0[ ] | P0_0 dig0
whismanoid 0:3edb3708c8c5 928 // | [ ] [ ] [ ] |
whismanoid 0:3edb3708c8c5 929 // | UNO_R3 GND MOSI 5V ____________/
whismanoid 0:3edb3708c8c5 930 // \_______________________/
whismanoid 0:3edb3708c8c5 931 //
whismanoid 0:3edb3708c8c5 932 #define HAS_digitalInOut0 1 // P0_0 TARGET_MAX32625MBED D0
whismanoid 0:3edb3708c8c5 933 #define HAS_digitalInOut1 1 // P0_1 TARGET_MAX32625MBED D1
whismanoid 0:3edb3708c8c5 934 #if APPLICATION_MAX11131
whismanoid 0:3edb3708c8c5 935 #define HAS_digitalInOut2 0 // P0_2 TARGET_MAX32625MBED D2 -- MAX11131 EOC DigitalIn
whismanoid 0:3edb3708c8c5 936 #else
whismanoid 0:3edb3708c8c5 937 #define HAS_digitalInOut2 1 // P0_2 TARGET_MAX32625MBED D2
whismanoid 0:3edb3708c8c5 938 #endif
whismanoid 0:3edb3708c8c5 939 #define HAS_digitalInOut3 1 // P0_3 TARGET_MAX32625MBED D3
whismanoid 0:3edb3708c8c5 940 #define HAS_digitalInOut4 1 // P0_4 TARGET_MAX32625MBED D4
whismanoid 0:3edb3708c8c5 941 #define HAS_digitalInOut5 1 // P0_5 TARGET_MAX32625MBED D5
whismanoid 0:3edb3708c8c5 942 #define HAS_digitalInOut6 1 // P0_6 TARGET_MAX32625MBED D6
whismanoid 0:3edb3708c8c5 943 #define HAS_digitalInOut7 1 // P0_7 TARGET_MAX32625MBED D7
whismanoid 0:3edb3708c8c5 944 #define HAS_digitalInOut8 1 // P1_4 TARGET_MAX32625MBED D8
whismanoid 0:3edb3708c8c5 945 #if APPLICATION_MAX11131
whismanoid 0:3edb3708c8c5 946 #define HAS_digitalInOut9 0 // P1_5 TARGET_MAX32625MBED D9 -- MAX11131 CNVST DigitalOut
whismanoid 0:3edb3708c8c5 947 #else
whismanoid 0:3edb3708c8c5 948 #define HAS_digitalInOut9 1 // P1_5 TARGET_MAX32625MBED D9
whismanoid 0:3edb3708c8c5 949 #endif
whismanoid 0:3edb3708c8c5 950 #if HAS_SPI
whismanoid 0:3edb3708c8c5 951 // avoid resource conflict between P5_0, P5_1, P5_2 SPI and DigitalInOut
whismanoid 0:3edb3708c8c5 952 #define HAS_digitalInOut10 0 // P1_3 TARGET_MAX32635MBED CS/10
whismanoid 0:3edb3708c8c5 953 #define HAS_digitalInOut11 0 // P1_1 TARGET_MAX32635MBED MOSI/11
whismanoid 0:3edb3708c8c5 954 #define HAS_digitalInOut12 0 // P1_2 TARGET_MAX32635MBED MISO/12
whismanoid 0:3edb3708c8c5 955 #define HAS_digitalInOut13 0 // P1_0 TARGET_MAX32635MBED SCK/13
whismanoid 0:3edb3708c8c5 956 #else // HAS_SPI
whismanoid 0:3edb3708c8c5 957 #define HAS_digitalInOut10 1 // P1_3 TARGET_MAX32635MBED CS/10
whismanoid 0:3edb3708c8c5 958 #define HAS_digitalInOut11 1 // P1_1 TARGET_MAX32635MBED MOSI/11
whismanoid 0:3edb3708c8c5 959 #define HAS_digitalInOut12 1 // P1_2 TARGET_MAX32635MBED MISO/12
whismanoid 0:3edb3708c8c5 960 #define HAS_digitalInOut13 1 // P1_0 TARGET_MAX32635MBED SCK/13
whismanoid 0:3edb3708c8c5 961 #endif // HAS_SPI
whismanoid 0:3edb3708c8c5 962 #if HAS_I2C
whismanoid 0:3edb3708c8c5 963 // avoid resource conflict between P5_7, P6_0 I2C and DigitalInOut
whismanoid 0:3edb3708c8c5 964 #define HAS_digitalInOut14 0 // P1_6 TARGET_MAX32635MBED A4/SDA (10pin digital connector)
whismanoid 0:3edb3708c8c5 965 #define HAS_digitalInOut15 0 // P1_7 TARGET_MAX32635MBED A5/SCL (10pin digital connector)
whismanoid 0:3edb3708c8c5 966 #define HAS_digitalInOut16 0 // P3_4 TARGET_MAX32635MBED A4/SDA (6pin analog connector)
whismanoid 0:3edb3708c8c5 967 #define HAS_digitalInOut17 0 // P3_5 TARGET_MAX32635MBED A5/SCL (6pin analog connector)
whismanoid 0:3edb3708c8c5 968 #else // HAS_I2C
whismanoid 0:3edb3708c8c5 969 #define HAS_digitalInOut14 1 // P1_6 TARGET_MAX32635MBED A4/SDA (10pin digital connector)
whismanoid 0:3edb3708c8c5 970 #define HAS_digitalInOut15 1 // P1_7 TARGET_MAX32635MBED A5/SCL (10pin digital connector)
whismanoid 0:3edb3708c8c5 971 #define HAS_digitalInOut16 1 // P3_4 TARGET_MAX32635MBED A4/SDA (6pin analog connector)
whismanoid 0:3edb3708c8c5 972 #define HAS_digitalInOut17 1 // P3_5 TARGET_MAX32635MBED A5/SCL (6pin analog connector)
whismanoid 0:3edb3708c8c5 973 #endif // HAS_I2C
whismanoid 0:3edb3708c8c5 974 #if HAS_digitalInOut0
whismanoid 0:3edb3708c8c5 975 DigitalInOut digitalInOut0(P0_0, PIN_INPUT, PullUp, 1); // P0_0 TARGET_MAX32625MBED D0
whismanoid 0:3edb3708c8c5 976 #endif
whismanoid 0:3edb3708c8c5 977 #if HAS_digitalInOut1
whismanoid 0:3edb3708c8c5 978 DigitalInOut digitalInOut1(P0_1, PIN_INPUT, PullUp, 1); // P0_1 TARGET_MAX32625MBED D1
whismanoid 0:3edb3708c8c5 979 #endif
whismanoid 0:3edb3708c8c5 980 #if HAS_digitalInOut2
whismanoid 0:3edb3708c8c5 981 DigitalInOut digitalInOut2(P0_2, PIN_INPUT, PullUp, 1); // P0_2 TARGET_MAX32625MBED D2
whismanoid 0:3edb3708c8c5 982 #endif
whismanoid 0:3edb3708c8c5 983 #if HAS_digitalInOut3
whismanoid 0:3edb3708c8c5 984 DigitalInOut digitalInOut3(P0_3, PIN_INPUT, PullUp, 1); // P0_3 TARGET_MAX32625MBED D3
whismanoid 0:3edb3708c8c5 985 #endif
whismanoid 0:3edb3708c8c5 986 #if HAS_digitalInOut4
whismanoid 0:3edb3708c8c5 987 DigitalInOut digitalInOut4(P0_4, PIN_INPUT, PullUp, 1); // P0_4 TARGET_MAX32625MBED D4
whismanoid 0:3edb3708c8c5 988 #endif
whismanoid 0:3edb3708c8c5 989 #if HAS_digitalInOut5
whismanoid 0:3edb3708c8c5 990 DigitalInOut digitalInOut5(P0_5, PIN_INPUT, PullUp, 1); // P0_5 TARGET_MAX32625MBED D5
whismanoid 0:3edb3708c8c5 991 #endif
whismanoid 0:3edb3708c8c5 992 #if HAS_digitalInOut6
whismanoid 0:3edb3708c8c5 993 DigitalInOut digitalInOut6(P0_6, PIN_INPUT, PullUp, 1); // P0_6 TARGET_MAX32625MBED D6
whismanoid 0:3edb3708c8c5 994 #endif
whismanoid 0:3edb3708c8c5 995 #if HAS_digitalInOut7
whismanoid 0:3edb3708c8c5 996 DigitalInOut digitalInOut7(P0_7, PIN_INPUT, PullUp, 1); // P0_7 TARGET_MAX32625MBED D7
whismanoid 0:3edb3708c8c5 997 #endif
whismanoid 0:3edb3708c8c5 998 #if HAS_digitalInOut8
whismanoid 0:3edb3708c8c5 999 DigitalInOut digitalInOut8(P1_4, PIN_INPUT, PullUp, 1); // P1_4 TARGET_MAX32625MBED D8
whismanoid 0:3edb3708c8c5 1000 #endif
whismanoid 0:3edb3708c8c5 1001 #if HAS_digitalInOut9
whismanoid 0:3edb3708c8c5 1002 DigitalInOut digitalInOut9(P1_5, PIN_INPUT, PullUp, 1); // P1_5 TARGET_MAX32625MBED D9
whismanoid 0:3edb3708c8c5 1003 #endif
whismanoid 0:3edb3708c8c5 1004 #if HAS_digitalInOut10
whismanoid 0:3edb3708c8c5 1005 DigitalInOut digitalInOut10(P1_3, PIN_INPUT, PullUp, 1); // P1_3 TARGET_MAX32635MBED CS/10
whismanoid 0:3edb3708c8c5 1006 #endif
whismanoid 0:3edb3708c8c5 1007 #if HAS_digitalInOut11
whismanoid 0:3edb3708c8c5 1008 DigitalInOut digitalInOut11(P1_1, PIN_INPUT, PullUp, 1); // P1_1 TARGET_MAX32635MBED MOSI/11
whismanoid 0:3edb3708c8c5 1009 #endif
whismanoid 0:3edb3708c8c5 1010 #if HAS_digitalInOut12
whismanoid 0:3edb3708c8c5 1011 DigitalInOut digitalInOut12(P1_2, PIN_INPUT, PullUp, 1); // P1_2 TARGET_MAX32635MBED MISO/12
whismanoid 0:3edb3708c8c5 1012 #endif
whismanoid 0:3edb3708c8c5 1013 #if HAS_digitalInOut13
whismanoid 0:3edb3708c8c5 1014 DigitalInOut digitalInOut13(P1_0, PIN_INPUT, PullUp, 1); // P1_0 TARGET_MAX32635MBED SCK/13
whismanoid 0:3edb3708c8c5 1015 #endif
whismanoid 0:3edb3708c8c5 1016 #if HAS_digitalInOut14
whismanoid 0:3edb3708c8c5 1017 // Ensure that the unused I2C pins do not interfere with analog inputs A4 and A5
whismanoid 0:3edb3708c8c5 1018 // DigitalInOut mode can be one of PullUp, PullDown, PullNone, OpenDrain
whismanoid 0:3edb3708c8c5 1019 DigitalInOut digitalInOut14(P1_6, PIN_INPUT, OpenDrain, 1); // P1_6 TARGET_MAX32635MBED A4/SDA (10pin digital connector)
whismanoid 0:3edb3708c8c5 1020 #endif
whismanoid 0:3edb3708c8c5 1021 #if HAS_digitalInOut15
whismanoid 0:3edb3708c8c5 1022 // Ensure that the unused I2C pins do not interfere with analog inputs A4 and A5
whismanoid 0:3edb3708c8c5 1023 DigitalInOut digitalInOut15(P1_7, PIN_INPUT, OpenDrain, 1); // P1_7 TARGET_MAX32635MBED A5/SCL (10pin digital connector)
whismanoid 0:3edb3708c8c5 1024 #endif
whismanoid 0:3edb3708c8c5 1025 #if HAS_digitalInOut16
whismanoid 0:3edb3708c8c5 1026 // Ensure that the unused I2C pins do not interfere with analog inputs A4 and A5
whismanoid 0:3edb3708c8c5 1027 // DigitalInOut mode can be one of PullUp, PullDown, PullNone, OpenDrain
whismanoid 0:3edb3708c8c5 1028 // PullUp-->3.4V, PullDown-->1.7V, PullNone-->3.5V, OpenDrain-->0.00V
whismanoid 0:3edb3708c8c5 1029 DigitalInOut digitalInOut16(P3_4, PIN_INPUT, OpenDrain, 0); // P3_4 TARGET_MAX32635MBED A4/SDA (6pin analog connector)
whismanoid 0:3edb3708c8c5 1030 #endif
whismanoid 0:3edb3708c8c5 1031 #if HAS_digitalInOut17
whismanoid 0:3edb3708c8c5 1032 // Ensure that the unused I2C pins do not interfere with analog inputs A4 and A5
whismanoid 0:3edb3708c8c5 1033 DigitalInOut digitalInOut17(P3_5, PIN_INPUT, OpenDrain, 0); // P3_5 TARGET_MAX32635MBED A5/SCL (6pin analog connector)
whismanoid 0:3edb3708c8c5 1034 #endif
whismanoid 0:3edb3708c8c5 1035 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 1036 #elif defined(TARGET_NUCLEO_F446RE) || defined(TARGET_NUCLEO_F401RE)
whismanoid 0:3edb3708c8c5 1037 #define HAS_digitalInOut0 0 // P0_0 TARGET_MAX32625MBED D0
whismanoid 0:3edb3708c8c5 1038 #define HAS_digitalInOut1 0 // P0_1 TARGET_MAX32625MBED D1
whismanoid 0:3edb3708c8c5 1039 #if APPLICATION_MAX11131
whismanoid 0:3edb3708c8c5 1040 #define HAS_digitalInOut2 0 // P0_2 TARGET_MAX32625MBED D2 -- MAX11131 EOC DigitalIn
whismanoid 0:3edb3708c8c5 1041 #else
whismanoid 0:3edb3708c8c5 1042 #define HAS_digitalInOut2 1 // P0_2 TARGET_MAX32625MBED D2
whismanoid 0:3edb3708c8c5 1043 #endif
whismanoid 0:3edb3708c8c5 1044 #define HAS_digitalInOut3 1 // P0_3 TARGET_MAX32625MBED D3
whismanoid 0:3edb3708c8c5 1045 #define HAS_digitalInOut4 1 // P0_4 TARGET_MAX32625MBED D4
whismanoid 0:3edb3708c8c5 1046 #define HAS_digitalInOut5 1 // P0_5 TARGET_MAX32625MBED D5
whismanoid 0:3edb3708c8c5 1047 #define HAS_digitalInOut6 1 // P0_6 TARGET_MAX32625MBED D6
whismanoid 0:3edb3708c8c5 1048 #define HAS_digitalInOut7 1 // P0_7 TARGET_MAX32625MBED D7
whismanoid 0:3edb3708c8c5 1049 #if APPLICATION_MAX5715
whismanoid 0:3edb3708c8c5 1050 #define HAS_digitalInOut8 0 // P1_4 TARGET_MAX32625MBED D8 -- MAX5715 CLRb DigitalOut
whismanoid 0:3edb3708c8c5 1051 #else
whismanoid 0:3edb3708c8c5 1052 #define HAS_digitalInOut8 1 // P1_4 TARGET_MAX32625MBED D8
whismanoid 0:3edb3708c8c5 1053 #endif
whismanoid 0:3edb3708c8c5 1054 #if APPLICATION_MAX5715
whismanoid 0:3edb3708c8c5 1055 #define HAS_digitalInOut9 0 // P1_5 TARGET_MAX32625MBED D9 -- MAX5715 LDACb DigitalOut
whismanoid 0:3edb3708c8c5 1056 #elif APPLICATION_MAX11131
whismanoid 0:3edb3708c8c5 1057 #define HAS_digitalInOut9 0 // P1_5 TARGET_MAX32625MBED D9 -- MAX11131 CNVST DigitalOut
whismanoid 0:3edb3708c8c5 1058 #else
whismanoid 0:3edb3708c8c5 1059 #define HAS_digitalInOut9 1 // P1_5 TARGET_MAX32625MBED D9
whismanoid 0:3edb3708c8c5 1060 #endif
whismanoid 0:3edb3708c8c5 1061 #if HAS_SPI
whismanoid 0:3edb3708c8c5 1062 // avoid resource conflict between P5_0, P5_1, P5_2 SPI and DigitalInOut
whismanoid 0:3edb3708c8c5 1063 // Arduino digital pin D10 SPI function is CS/10
whismanoid 0:3edb3708c8c5 1064 // Arduino digital pin D11 SPI function is MOSI/11
whismanoid 0:3edb3708c8c5 1065 // Arduino digital pin D12 SPI function is MISO/12
whismanoid 0:3edb3708c8c5 1066 // Arduino digital pin D13 SPI function is SCK/13
whismanoid 0:3edb3708c8c5 1067 #define HAS_digitalInOut10 0
whismanoid 0:3edb3708c8c5 1068 #define HAS_digitalInOut11 0
whismanoid 0:3edb3708c8c5 1069 #define HAS_digitalInOut12 0
whismanoid 0:3edb3708c8c5 1070 #define HAS_digitalInOut13 0
whismanoid 0:3edb3708c8c5 1071 #else // HAS_SPI
whismanoid 0:3edb3708c8c5 1072 #define HAS_digitalInOut10 1
whismanoid 0:3edb3708c8c5 1073 #define HAS_digitalInOut11 1
whismanoid 0:3edb3708c8c5 1074 #define HAS_digitalInOut12 1
whismanoid 0:3edb3708c8c5 1075 #define HAS_digitalInOut13 1
whismanoid 0:3edb3708c8c5 1076 #endif // HAS_SPI
whismanoid 0:3edb3708c8c5 1077 #if HAS_I2C
whismanoid 0:3edb3708c8c5 1078 // avoid resource conflict between P5_7, P6_0 I2C and DigitalInOut
whismanoid 0:3edb3708c8c5 1079 // Arduino digital pin D14 I2C function is A4/SDA (10pin digital connector)
whismanoid 0:3edb3708c8c5 1080 // Arduino digital pin D15 I2C function is A5/SCL (10pin digital connector)
whismanoid 0:3edb3708c8c5 1081 // Arduino digital pin D16 I2C function is A4/SDA (6pin analog connector)
whismanoid 0:3edb3708c8c5 1082 // Arduino digital pin D17 I2C function is A5/SCL (6pin analog connector)
whismanoid 0:3edb3708c8c5 1083 #define HAS_digitalInOut14 0
whismanoid 0:3edb3708c8c5 1084 #define HAS_digitalInOut15 0
whismanoid 0:3edb3708c8c5 1085 #define HAS_digitalInOut16 0
whismanoid 0:3edb3708c8c5 1086 #define HAS_digitalInOut17 0
whismanoid 0:3edb3708c8c5 1087 #else // HAS_I2C
whismanoid 0:3edb3708c8c5 1088 #define HAS_digitalInOut14 1
whismanoid 0:3edb3708c8c5 1089 #define HAS_digitalInOut15 1
whismanoid 0:3edb3708c8c5 1090 #define HAS_digitalInOut16 0
whismanoid 0:3edb3708c8c5 1091 #define HAS_digitalInOut17 0
whismanoid 0:3edb3708c8c5 1092 #endif // HAS_I2C
whismanoid 0:3edb3708c8c5 1093 #if HAS_digitalInOut0
whismanoid 0:3edb3708c8c5 1094 DigitalInOut digitalInOut0(D0, PIN_INPUT, PullUp, 1);
whismanoid 0:3edb3708c8c5 1095 #endif
whismanoid 0:3edb3708c8c5 1096 #if HAS_digitalInOut1
whismanoid 0:3edb3708c8c5 1097 DigitalInOut digitalInOut1(D1, PIN_INPUT, PullUp, 1);
whismanoid 0:3edb3708c8c5 1098 #endif
whismanoid 0:3edb3708c8c5 1099 #if HAS_digitalInOut2
whismanoid 0:3edb3708c8c5 1100 DigitalInOut digitalInOut2(D2, PIN_INPUT, PullUp, 1);
whismanoid 0:3edb3708c8c5 1101 #endif
whismanoid 0:3edb3708c8c5 1102 #if HAS_digitalInOut3
whismanoid 0:3edb3708c8c5 1103 DigitalInOut digitalInOut3(D3, PIN_INPUT, PullUp, 1);
whismanoid 0:3edb3708c8c5 1104 #endif
whismanoid 0:3edb3708c8c5 1105 #if HAS_digitalInOut4
whismanoid 0:3edb3708c8c5 1106 DigitalInOut digitalInOut4(D4, PIN_INPUT, PullUp, 1);
whismanoid 0:3edb3708c8c5 1107 #endif
whismanoid 0:3edb3708c8c5 1108 #if HAS_digitalInOut5
whismanoid 0:3edb3708c8c5 1109 DigitalInOut digitalInOut5(D5, PIN_INPUT, PullUp, 1);
whismanoid 0:3edb3708c8c5 1110 #endif
whismanoid 0:3edb3708c8c5 1111 #if HAS_digitalInOut6
whismanoid 0:3edb3708c8c5 1112 DigitalInOut digitalInOut6(D6, PIN_INPUT, PullUp, 1);
whismanoid 0:3edb3708c8c5 1113 #endif
whismanoid 0:3edb3708c8c5 1114 #if HAS_digitalInOut7
whismanoid 0:3edb3708c8c5 1115 DigitalInOut digitalInOut7(D7, PIN_INPUT, PullUp, 1);
whismanoid 0:3edb3708c8c5 1116 #endif
whismanoid 0:3edb3708c8c5 1117 #if HAS_digitalInOut8
whismanoid 0:3edb3708c8c5 1118 DigitalInOut digitalInOut8(D8, PIN_INPUT, PullUp, 1);
whismanoid 0:3edb3708c8c5 1119 #endif
whismanoid 0:3edb3708c8c5 1120 #if HAS_digitalInOut9
whismanoid 0:3edb3708c8c5 1121 DigitalInOut digitalInOut9(D9, PIN_INPUT, PullUp, 1);
whismanoid 0:3edb3708c8c5 1122 #endif
whismanoid 0:3edb3708c8c5 1123 #if HAS_digitalInOut10
whismanoid 0:3edb3708c8c5 1124 // Arduino digital pin D10 SPI function is CS/10
whismanoid 0:3edb3708c8c5 1125 DigitalInOut digitalInOut10(D10, PIN_INPUT, PullUp, 1);
whismanoid 0:3edb3708c8c5 1126 #endif
whismanoid 0:3edb3708c8c5 1127 #if HAS_digitalInOut11
whismanoid 0:3edb3708c8c5 1128 // Arduino digital pin D11 SPI function is MOSI/11
whismanoid 0:3edb3708c8c5 1129 DigitalInOut digitalInOut11(D11, PIN_INPUT, PullUp, 1);
whismanoid 0:3edb3708c8c5 1130 #endif
whismanoid 0:3edb3708c8c5 1131 #if HAS_digitalInOut12
whismanoid 0:3edb3708c8c5 1132 // Arduino digital pin D12 SPI function is MISO/12
whismanoid 0:3edb3708c8c5 1133 DigitalInOut digitalInOut12(D12, PIN_INPUT, PullUp, 1);
whismanoid 0:3edb3708c8c5 1134 #endif
whismanoid 0:3edb3708c8c5 1135 #if HAS_digitalInOut13
whismanoid 0:3edb3708c8c5 1136 // Arduino digital pin D13 SPI function is SCK/13
whismanoid 0:3edb3708c8c5 1137 DigitalInOut digitalInOut13(D13, PIN_INPUT, PullUp, 1);
whismanoid 0:3edb3708c8c5 1138 #endif
whismanoid 0:3edb3708c8c5 1139 #if HAS_digitalInOut14
whismanoid 0:3edb3708c8c5 1140 // Arduino digital pin D14 I2C function is A4/SDA (10pin digital connector)
whismanoid 0:3edb3708c8c5 1141 DigitalInOut digitalInOut14(D14, PIN_INPUT, PullUp, 1);
whismanoid 0:3edb3708c8c5 1142 #endif
whismanoid 0:3edb3708c8c5 1143 #if HAS_digitalInOut15
whismanoid 0:3edb3708c8c5 1144 // Arduino digital pin D15 I2C function is A5/SCL (10pin digital connector)
whismanoid 0:3edb3708c8c5 1145 DigitalInOut digitalInOut15(D15, PIN_INPUT, PullUp, 1);
whismanoid 0:3edb3708c8c5 1146 #endif
whismanoid 0:3edb3708c8c5 1147 #if HAS_digitalInOut16
whismanoid 0:3edb3708c8c5 1148 // Arduino digital pin D16 I2C function is A4/SDA (6pin analog connector)
whismanoid 0:3edb3708c8c5 1149 DigitalInOut digitalInOut16(D16, PIN_INPUT, PullUp, 1);
whismanoid 0:3edb3708c8c5 1150 #endif
whismanoid 0:3edb3708c8c5 1151 #if HAS_digitalInOut17
whismanoid 0:3edb3708c8c5 1152 // Arduino digital pin D17 I2C function is A5/SCL (6pin analog connector)
whismanoid 0:3edb3708c8c5 1153 DigitalInOut digitalInOut17(D17, PIN_INPUT, PullUp, 1);
whismanoid 0:3edb3708c8c5 1154 #endif
whismanoid 0:3edb3708c8c5 1155 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 1156 #elif defined(TARGET_LPC1768)
whismanoid 0:3edb3708c8c5 1157 #define HAS_digitalInOut0 1
whismanoid 0:3edb3708c8c5 1158 #define HAS_digitalInOut1 1
whismanoid 0:3edb3708c8c5 1159 #define HAS_digitalInOut2 1
whismanoid 0:3edb3708c8c5 1160 #define HAS_digitalInOut3 1
whismanoid 0:3edb3708c8c5 1161 #define HAS_digitalInOut4 1
whismanoid 0:3edb3708c8c5 1162 #define HAS_digitalInOut5 1
whismanoid 0:3edb3708c8c5 1163 #define HAS_digitalInOut6 1
whismanoid 0:3edb3708c8c5 1164 #define HAS_digitalInOut7 1
whismanoid 0:3edb3708c8c5 1165 #define HAS_digitalInOut8 1
whismanoid 0:3edb3708c8c5 1166 #define HAS_digitalInOut9 1
whismanoid 0:3edb3708c8c5 1167 // #define HAS_digitalInOut10 1
whismanoid 0:3edb3708c8c5 1168 // #define HAS_digitalInOut11 1
whismanoid 0:3edb3708c8c5 1169 // #define HAS_digitalInOut12 1
whismanoid 0:3edb3708c8c5 1170 // #define HAS_digitalInOut13 1
whismanoid 0:3edb3708c8c5 1171 // #define HAS_digitalInOut14 1
whismanoid 0:3edb3708c8c5 1172 // #define HAS_digitalInOut15 1
whismanoid 0:3edb3708c8c5 1173 #if HAS_digitalInOut0
whismanoid 0:3edb3708c8c5 1174 DigitalInOut digitalInOut0(p5, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P0.9/I2STX_SDA/MOSI1/MAT2.3
whismanoid 0:3edb3708c8c5 1175 #endif
whismanoid 0:3edb3708c8c5 1176 #if HAS_digitalInOut1
whismanoid 0:3edb3708c8c5 1177 DigitalInOut digitalInOut1(p6, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P0.8/I2STX_WS/MISO1/MAT2.2
whismanoid 0:3edb3708c8c5 1178 #endif
whismanoid 0:3edb3708c8c5 1179 #if HAS_digitalInOut2
whismanoid 0:3edb3708c8c5 1180 DigitalInOut digitalInOut2(p7, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P0.7/I2STX_CLK/SCK1/MAT2.1
whismanoid 0:3edb3708c8c5 1181 #endif
whismanoid 0:3edb3708c8c5 1182 #if HAS_digitalInOut3
whismanoid 0:3edb3708c8c5 1183 DigitalInOut digitalInOut3(p8, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P0.6/I2SRX_SDA/SSEL1/MAT2.0
whismanoid 0:3edb3708c8c5 1184 #endif
whismanoid 0:3edb3708c8c5 1185 #if HAS_digitalInOut4
whismanoid 0:3edb3708c8c5 1186 DigitalInOut digitalInOut4(p9, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P0.0/CAN_RX1/TXD3/SDA1
whismanoid 0:3edb3708c8c5 1187 #endif
whismanoid 0:3edb3708c8c5 1188 #if HAS_digitalInOut5
whismanoid 0:3edb3708c8c5 1189 DigitalInOut digitalInOut5(p10, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P0.1/CAN_TX1/RXD3/SCL1
whismanoid 0:3edb3708c8c5 1190 #endif
whismanoid 0:3edb3708c8c5 1191 #if HAS_digitalInOut6
whismanoid 0:3edb3708c8c5 1192 DigitalInOut digitalInOut6(p11, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P0.18/DCD1/MOSI0/MOSI1
whismanoid 0:3edb3708c8c5 1193 #endif
whismanoid 0:3edb3708c8c5 1194 #if HAS_digitalInOut7
whismanoid 0:3edb3708c8c5 1195 DigitalInOut digitalInOut7(p12, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P0.17/CTS1/MISO0/MISO
whismanoid 0:3edb3708c8c5 1196 #endif
whismanoid 0:3edb3708c8c5 1197 #if HAS_digitalInOut8
whismanoid 0:3edb3708c8c5 1198 DigitalInOut digitalInOut8(p13, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P0.15/TXD1/SCK0/SCK
whismanoid 0:3edb3708c8c5 1199 #endif
whismanoid 0:3edb3708c8c5 1200 #if HAS_digitalInOut9
whismanoid 0:3edb3708c8c5 1201 DigitalInOut digitalInOut9(p14, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P0.16/RXD1/SSEL0/SSEL
whismanoid 0:3edb3708c8c5 1202 #endif
whismanoid 0:3edb3708c8c5 1203 //
whismanoid 0:3edb3708c8c5 1204 // these pins support analog input analogIn0 .. analogIn5
whismanoid 0:3edb3708c8c5 1205 //DigitalInOut digitalInOut_(p15, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P0.23/AD0.0/I2SRX_CLK/CAP3.0
whismanoid 0:3edb3708c8c5 1206 //DigitalInOut digitalInOut_(p16, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P0.24/AD0.1/I2SRX_WS/CAP3.1
whismanoid 0:3edb3708c8c5 1207 //DigitalInOut digitalInOut_(p17, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P0.25/AD0.2/I2SRX_SDA/TXD3
whismanoid 0:3edb3708c8c5 1208 //DigitalInOut digitalInOut_(p18, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P0.26/AD0.3/AOUT/RXD3
whismanoid 0:3edb3708c8c5 1209 //DigitalInOut digitalInOut_(p19, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P1.30/VBUS/AD0.4
whismanoid 0:3edb3708c8c5 1210 //DigitalInOut digitalInOut_(p20, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P1.31/SCK1/AD0.5
whismanoid 0:3edb3708c8c5 1211 //
whismanoid 0:3edb3708c8c5 1212 // these pins support PWM pwmDriver1 .. pwmDriver6
whismanoid 0:3edb3708c8c5 1213 //DigitalInOut digitalInOut_(p21, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P2.5/PWM1.6/DTR1/TRACEDATA0
whismanoid 0:3edb3708c8c5 1214 //DigitalInOut digitalInOut_(p22, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P2.4/PWM1.5/DSR1/TRACEDATA1
whismanoid 0:3edb3708c8c5 1215 //DigitalInOut digitalInOut_(p23, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P2.3/PWM1.4/DCD1/TRACEDATA2
whismanoid 0:3edb3708c8c5 1216 //DigitalInOut digitalInOut_(p24, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P2.2/PWM1.3/CTS1/TRACEDATA3
whismanoid 0:3edb3708c8c5 1217 //DigitalInOut digitalInOut_(p25, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P2.1/PWM1.2/RXD1
whismanoid 0:3edb3708c8c5 1218 //DigitalInOut digitalInOut_(p26, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P2.0/PWM1.1/TXD1/TRACECLK
whismanoid 0:3edb3708c8c5 1219 //
whismanoid 0:3edb3708c8c5 1220 // these could be additional digitalInOut pins
whismanoid 0:3edb3708c8c5 1221 #if HAS_digitalInOut10
whismanoid 0:3edb3708c8c5 1222 DigitalInOut digitalInOut10(p27, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P0.11/RXD2/SCL2/MAT3.1
whismanoid 0:3edb3708c8c5 1223 #endif
whismanoid 0:3edb3708c8c5 1224 #if HAS_digitalInOut11
whismanoid 0:3edb3708c8c5 1225 DigitalInOut digitalInOut11(p28, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P0.10/TXD2/SDA2/MAT3.0
whismanoid 0:3edb3708c8c5 1226 #endif
whismanoid 0:3edb3708c8c5 1227 #if HAS_digitalInOut12
whismanoid 0:3edb3708c8c5 1228 DigitalInOut digitalInOut12(p29, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P0.5/I2SRX_WS/CAN_TX2/CAP2.1
whismanoid 0:3edb3708c8c5 1229 #endif
whismanoid 0:3edb3708c8c5 1230 #if HAS_digitalInOut13
whismanoid 0:3edb3708c8c5 1231 DigitalInOut digitalInOut13(p30, PIN_INPUT, PullUp, 1); // TARGET_LPC1768 P0.4/I2SRX_CLK/CAN_RX2/CAP2.0
whismanoid 0:3edb3708c8c5 1232 #endif
whismanoid 0:3edb3708c8c5 1233 #if HAS_digitalInOut14
whismanoid 0:3edb3708c8c5 1234 DigitalInOut digitalInOut14(___, PIN_INPUT, PullUp, 1);
whismanoid 0:3edb3708c8c5 1235 #endif
whismanoid 0:3edb3708c8c5 1236 #if HAS_digitalInOut15
whismanoid 0:3edb3708c8c5 1237 DigitalInOut digitalInOut15(___, PIN_INPUT, PullUp, 1);
whismanoid 0:3edb3708c8c5 1238 #endif
whismanoid 0:3edb3708c8c5 1239 #else
whismanoid 0:3edb3708c8c5 1240 // unknown target
whismanoid 0:3edb3708c8c5 1241 #endif
whismanoid 0:3edb3708c8c5 1242 // uncrustify-0.66.1 *INDENT-ON*
whismanoid 0:3edb3708c8c5 1243 #if HAS_digitalInOut0 || HAS_digitalInOut1 \
whismanoid 0:3edb3708c8c5 1244 || HAS_digitalInOut2 || HAS_digitalInOut3 \
whismanoid 0:3edb3708c8c5 1245 || HAS_digitalInOut4 || HAS_digitalInOut5 \
whismanoid 0:3edb3708c8c5 1246 || HAS_digitalInOut6 || HAS_digitalInOut7 \
whismanoid 0:3edb3708c8c5 1247 || HAS_digitalInOut8 || HAS_digitalInOut9 \
whismanoid 0:3edb3708c8c5 1248 || HAS_digitalInOut10 || HAS_digitalInOut11 \
whismanoid 0:3edb3708c8c5 1249 || HAS_digitalInOut12 || HAS_digitalInOut13 \
whismanoid 0:3edb3708c8c5 1250 || HAS_digitalInOut14 || HAS_digitalInOut15 \
whismanoid 0:3edb3708c8c5 1251 || HAS_digitalInOut16 || HAS_digitalInOut17
whismanoid 0:3edb3708c8c5 1252 #define HAS_digitalInOuts 1
whismanoid 0:3edb3708c8c5 1253 #endif
whismanoid 0:3edb3708c8c5 1254
whismanoid 0:3edb3708c8c5 1255 // uncrustify-0.66.1 *INDENT-OFF*
whismanoid 0:3edb3708c8c5 1256 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 1257 // Declare the PwmOut driver
whismanoid 0:3edb3708c8c5 1258 // Optional PwmOut support. If there is only one it should be pwmDriver1.
whismanoid 0:3edb3708c8c5 1259 // P) PWM pin#, duty cycle
whismanoid 0:3edb3708c8c5 1260 #if defined(TARGET_MAX32630)
whismanoid 0:3edb3708c8c5 1261 // +-------------[microUSB]-------------+
whismanoid 0:3edb3708c8c5 1262 // | J1 MAX32630FTHR J2 |
whismanoid 0:3edb3708c8c5 1263 // | [ ] RST GND [ ] |
whismanoid 0:3edb3708c8c5 1264 // | [ ] 3V3 BAT+[ ] |
whismanoid 0:3edb3708c8c5 1265 // | [ ] 1V8 reset SW1 |
whismanoid 0:3edb3708c8c5 1266 // | [ ] GND J4 J3 |
whismanoid 0:3edb3708c8c5 1267 // | [ ] AIN_0 1.2Vfs (bat) SYS [ ] |
whismanoid 0:3edb3708c8c5 1268 // | [ ] AIN_1 1.2Vfs PWR [ ] |
whismanoid 0:3edb3708c8c5 1269 // | [ ] AIN_2 1.2Vfs +5V VBUS [ ] |
whismanoid 0:3edb3708c8c5 1270 // | [ ] AIN_3 1.2Vfs 1-WIRE P4_0 [x] | pwm4
whismanoid 0:3edb3708c8c5 1271 // | [ ] P5_7 SDA2 SRN P5_6 [x] | pwm5
whismanoid 0:3edb3708c8c5 1272 // | [ ] P6_0 SCL2 SDIO3 P5_5 [x] | pwm6
whismanoid 0:3edb3708c8c5 1273 // pwm13 | [ ] P5_0 SCLK SDIO2 P5_4 [x] | pwm7
whismanoid 0:3edb3708c8c5 1274 // pwm14 | [ ] P5_1 MOSI SSEL P5_3 [x] | pwm8
whismanoid 0:3edb3708c8c5 1275 // pwm3 | [x] P5_2 MISO RTS P3_3 [x] | pwm9
whismanoid 0:3edb3708c8c5 1276 // pwm2 | [x] P3_0 RX CTS P3_2 [ ] | pwm10
whismanoid 0:3edb3708c8c5 1277 // pwm1 | [x] P3_1 TX SCL P3_5 [ ] | pwm11
whismanoid 0:3edb3708c8c5 1278 // | [ ] GND SDA P3_4 [ ] | pwm12
whismanoid 0:3edb3708c8c5 1279 // +------------------------------------+
whismanoid 0:3edb3708c8c5 1280 // MAX32630FTHR mbed PwmOut driver is limited to 32-bit counter value;
whismanoid 0:3edb3708c8c5 1281 // see pwmout_update function in mbed-os/targets/TARGET_Maxim/TARGET_MAX32630/pwmout_api.c
whismanoid 0:3edb3708c8c5 1282 // int div = (obj->period * (SystemCoreClock / 1000000))/32;
whismanoid 0:3edb3708c8c5 1283 #if HAS_SPI
whismanoid 0:3edb3708c8c5 1284 // avoid resource conflict between P5_0, P5_1, P5_2 SPI and DigitalInOut
whismanoid 0:3edb3708c8c5 1285 #define HAS_pwmDriver13 0 // P5_0 PT8 TARGET_MAX32630 J1.11 pass ok; conflict PT8 P3_0 P5_0
whismanoid 0:3edb3708c8c5 1286 #define HAS_pwmDriver14 0 // P5_1 PT9 TARGET_MAX32630 J1.12 pass ok; conflict PT9 P3_1 P5_1
whismanoid 0:3edb3708c8c5 1287 #define HAS_pwmDriver3 0 // P5_2 PT10 TARGET_MAX32630 J1.13 pass ok; conflict PT10 P3_2 P5_2
whismanoid 0:3edb3708c8c5 1288 #define HAS_pwmDriver2 0 // P3_0 PT8 TARGET_MAX32630 J1.14 pass ok; conflict PT8 P3_0 P5_0
whismanoid 0:3edb3708c8c5 1289 #endif
whismanoid 0:3edb3708c8c5 1290 // #define HAS_pwmDriver0 0 // not assigned
whismanoid 0:3edb3708c8c5 1291 # ifndef HAS_pwmDriver1
whismanoid 0:3edb3708c8c5 1292 //~ #define HAS_pwmDriver1 1 // P3_1 PT9 TARGET_MAX32630 J1.15 pass ok; conflict PT9 P3_1 P5_1
whismanoid 0:3edb3708c8c5 1293 # endif
whismanoid 0:3edb3708c8c5 1294 # ifndef HAS_pwmDriver2
whismanoid 0:3edb3708c8c5 1295 #define HAS_pwmDriver2 1 // P3_0 PT8 TARGET_MAX32630 J1.14 pass ok; conflict PT8 P3_0 P5_0
whismanoid 0:3edb3708c8c5 1296 # endif
whismanoid 0:3edb3708c8c5 1297 # ifndef HAS_pwmDriver3
whismanoid 0:3edb3708c8c5 1298 #define HAS_pwmDriver3 1 // P5_2 PT10 TARGET_MAX32630 J1.13 pass ok; conflict PT10 P3_2 P5_2
whismanoid 0:3edb3708c8c5 1299 # endif
whismanoid 0:3edb3708c8c5 1300 # ifndef HAS_pwmDriver4
whismanoid 0:3edb3708c8c5 1301 //~ #define HAS_pwmDriver4 1 // P4_0 PT0 TARGET_MAX32630 J3.4 pass ok
whismanoid 0:3edb3708c8c5 1302 # endif
whismanoid 0:3edb3708c8c5 1303 # ifndef HAS_pwmDriver5
whismanoid 0:3edb3708c8c5 1304 //~ #define HAS_pwmDriver5 1 // P5_6 PT14 TARGET_MAX32630 J3.5 pass ok
whismanoid 0:3edb3708c8c5 1305 # endif
whismanoid 0:3edb3708c8c5 1306 # ifndef HAS_pwmDriver6
whismanoid 0:3edb3708c8c5 1307 //~ #define HAS_pwmDriver6 1 // P5_5 PT13 TARGET_MAX32630 J3.6 pass ok; conflict PT13 P3_5 P5_5
whismanoid 0:3edb3708c8c5 1308 # endif
whismanoid 0:3edb3708c8c5 1309 # ifndef HAS_pwmDriver7
whismanoid 0:3edb3708c8c5 1310 //~ #define HAS_pwmDriver7 1 // P5_4 PT12 TARGET_MAX32630 J3.7 pass ok; conflict PT12 P3_4 P5_4
whismanoid 0:3edb3708c8c5 1311 # endif
whismanoid 0:3edb3708c8c5 1312 # ifndef HAS_pwmDriver8
whismanoid 0:3edb3708c8c5 1313 //~ #define HAS_pwmDriver8 1 // P5_3 PT11 TARGET_MAX32630 J3.8 pass ok; conflict PT11 P3_3 P5_3
whismanoid 0:3edb3708c8c5 1314 # endif
whismanoid 0:3edb3708c8c5 1315 # ifndef HAS_pwmDriver9
whismanoid 0:3edb3708c8c5 1316 // #define HAS_pwmDriver9 1 // P3_3 PT11 TARGET_MAX32630 J3.9 pass ok; conflict PT11 P3_3 P5_3
whismanoid 0:3edb3708c8c5 1317 # endif
whismanoid 0:3edb3708c8c5 1318 # ifndef HAS_pwmDriver10
whismanoid 0:3edb3708c8c5 1319 // #define HAS_pwmDriver10 1 // P3_2 PT10 TARGET_MAX32630 J3.10 pass ok; conflict PT10 P3_2 P5_2
whismanoid 0:3edb3708c8c5 1320 # endif
whismanoid 0:3edb3708c8c5 1321 # ifndef HAS_pwmDriver11
whismanoid 0:3edb3708c8c5 1322 // #define HAS_pwmDriver11 1 // P3_5 PT13 TARGET_MAX32630 J3.11 pass ok; conflict PT13 P3_5 P5_5
whismanoid 0:3edb3708c8c5 1323 # endif
whismanoid 0:3edb3708c8c5 1324 # ifndef HAS_pwmDriver12
whismanoid 0:3edb3708c8c5 1325 // #define HAS_pwmDriver12 1 // P3_4 PT12 TARGET_MAX32630 J3.12 pass ok; conflict PT12 P3_4 P5_4
whismanoid 0:3edb3708c8c5 1326 # endif
whismanoid 0:3edb3708c8c5 1327 # ifndef HAS_pwmDriver13
whismanoid 0:3edb3708c8c5 1328 // #define HAS_pwmDriver13 1 // P5_0 PT8 TARGET_MAX32630 J1.11 pass ok; conflict PT8 P3_0 P5_0
whismanoid 0:3edb3708c8c5 1329 # endif
whismanoid 0:3edb3708c8c5 1330 # ifndef HAS_pwmDriver14
whismanoid 0:3edb3708c8c5 1331 // #define HAS_pwmDriver14 1 // P5_1 PT9 TARGET_MAX32630 J1.12 pass ok; conflict PT9 P3_1 P5_1
whismanoid 0:3edb3708c8c5 1332 # endif
whismanoid 0:3edb3708c8c5 1333 # ifndef HAS_pwmDriver15
whismanoid 0:3edb3708c8c5 1334 // #define HAS_pwmDriver15 0 // not assigned
whismanoid 0:3edb3708c8c5 1335 # endif
whismanoid 0:3edb3708c8c5 1336 #if HAS_pwmDriver0
whismanoid 0:3edb3708c8c5 1337 PwmOut pwmDriver0(____); // not assigned
whismanoid 0:3edb3708c8c5 1338 #endif
whismanoid 0:3edb3708c8c5 1339 #if HAS_pwmDriver1
whismanoid 0:3edb3708c8c5 1340 PwmOut pwmDriver1(P3_1); // PT9 TARGET_MAX32630 J1.15 pass ok
whismanoid 0:3edb3708c8c5 1341 // Investigating which TARGET_MAX32630 PWM drivers work.
whismanoid 0:3edb3708c8c5 1342 // fail assert = runtime failure at system boot, as the only pwm pin
whismanoid 0:3edb3708c8c5 1343 // pass? = no runtime failure as the only pwm pin, may be ok
whismanoid 0:3edb3708c8c5 1344 // pass ok = plays well with others
whismanoid 0:3edb3708c8c5 1345 // PT0..PT15 identify which Pulse Train resource drives that GPIO pin
whismanoid 0:3edb3708c8c5 1346 //PwmOut pwmDriver1(P5_7); // P5_7 PT15 TARGET_MAX32630 J1.9 fail assert; resource conflict
whismanoid 0:3edb3708c8c5 1347 //PwmOut pwmDriver1(P6_0); // P6_0 PT0 TARGET_MAX32630 J1.10 fail assert; resource conflict
whismanoid 0:3edb3708c8c5 1348 //PwmOut pwmDriver1(P5_0); // P5_0 PT8 TARGET_MAX32630 J1.11 pass ok; conflict PT8 P3_0 P5_0
whismanoid 0:3edb3708c8c5 1349 //PwmOut pwmDriver1(P5_1); // P5_1 PT9 TARGET_MAX32630 J1.12 pass ok; conflict PT9 P3_1 P5_1
whismanoid 0:3edb3708c8c5 1350 //PwmOut pwmDriver1(P5_2); // P5_2 PT10 TARGET_MAX32630 J1.13 pass ok; conflict PT10 P3_2 P5_2
whismanoid 0:3edb3708c8c5 1351 //PwmOut pwmDriver1(P3_0); // P3_0 PT8 TARGET_MAX32630 J1.14 pass ok; conflict PT8 P3_0 P5_0
whismanoid 0:3edb3708c8c5 1352 //PwmOut pwmDriver1(P3_1); // P3_1 PT9 TARGET_MAX32630 J1.15 pass ok; conflict PT9 P3_1 P5_1
whismanoid 0:3edb3708c8c5 1353 //
whismanoid 0:3edb3708c8c5 1354 //PwmOut pwmDriver1(P4_0); // P4_0 PT0 TARGET_MAX32630 J3.4 pass ok
whismanoid 0:3edb3708c8c5 1355 //PwmOut pwmDriver1(P5_6); // P5_6 PT14 TARGET_MAX32630 J3.5 pass ok
whismanoid 0:3edb3708c8c5 1356 //PwmOut pwmDriver1(P5_5); // P5_5 PT13 TARGET_MAX32630 J3.6 pass ok; conflict PT13 P3_5 P5_5
whismanoid 0:3edb3708c8c5 1357 //PwmOut pwmDriver1(P5_4); // P5_4 PT12 TARGET_MAX32630 J3.7 pass ok; conflict PT12 P3_4 P5_4
whismanoid 0:3edb3708c8c5 1358 //PwmOut pwmDriver1(P5_3); // P5_3 PT11 TARGET_MAX32630 J3.8 pass ok; conflict PT11 P3_3 P5_3
whismanoid 0:3edb3708c8c5 1359 //PwmOut pwmDriver1(P3_3); // P3_3 PT11 TARGET_MAX32630 J3.9 pass ok; conflict PT11 P3_3 P5_3
whismanoid 0:3edb3708c8c5 1360 //PwmOut pwmDriver1(P3_2); // P3_2 PT10 TARGET_MAX32630 J3.10 pass ok; conflict PT10 P3_2 P5_2
whismanoid 0:3edb3708c8c5 1361 //PwmOut pwmDriver1(P3_5); // P3_5 PT13 TARGET_MAX32630 J3.11 pass ok; conflict PT13 P3_5 P5_5
whismanoid 0:3edb3708c8c5 1362 //PwmOut pwmDriver1(P3_4); // P3_4 PT12 TARGET_MAX32630 J3.12 pass ok; conflict PT12 P3_4 P5_4
whismanoid 0:3edb3708c8c5 1363 #endif
whismanoid 0:3edb3708c8c5 1364 #if HAS_pwmDriver2
whismanoid 0:3edb3708c8c5 1365 PwmOut pwmDriver2(P3_0); // P3_0 PT8 TARGET_MAX32630 J1.14 pass ok; conflict PT8 P3_0 P5_0
whismanoid 0:3edb3708c8c5 1366 #endif
whismanoid 0:3edb3708c8c5 1367 #if HAS_pwmDriver3
whismanoid 0:3edb3708c8c5 1368 PwmOut pwmDriver3(P5_2); // P5_2 PT10 TARGET_MAX32630 J1.13 pass ok; conflict PT10 P3_2 P5_2
whismanoid 0:3edb3708c8c5 1369 #endif
whismanoid 0:3edb3708c8c5 1370 #if HAS_pwmDriver4
whismanoid 0:3edb3708c8c5 1371 PwmOut pwmDriver4(P4_0); // P4_0 PT0 TARGET_MAX32630 J3.4 pass ok
whismanoid 0:3edb3708c8c5 1372 #endif
whismanoid 0:3edb3708c8c5 1373 #if HAS_pwmDriver5
whismanoid 0:3edb3708c8c5 1374 PwmOut pwmDriver5(P5_6); // P5_6 PT14 TARGET_MAX32630 J3.5 pass ok
whismanoid 0:3edb3708c8c5 1375 #endif
whismanoid 0:3edb3708c8c5 1376 #if HAS_pwmDriver6
whismanoid 0:3edb3708c8c5 1377 PwmOut pwmDriver6(P5_5); // P5_5 PT13 TARGET_MAX32630 J3.6 pass ok; conflict PT13 P3_5 P5_5
whismanoid 0:3edb3708c8c5 1378 #endif
whismanoid 0:3edb3708c8c5 1379 #if HAS_pwmDriver7
whismanoid 0:3edb3708c8c5 1380 PwmOut pwmDriver7(P5_4); // P5_4 PT12 TARGET_MAX32630 J3.7 pass ok; conflict PT12 P3_4 P5_4
whismanoid 0:3edb3708c8c5 1381 #endif
whismanoid 0:3edb3708c8c5 1382 #if HAS_pwmDriver8
whismanoid 0:3edb3708c8c5 1383 PwmOut pwmDriver8(P5_3); // P5_3 PT11 TARGET_MAX32630 J3.8 pass ok; conflict PT11 P3_3 P5_3
whismanoid 0:3edb3708c8c5 1384 #endif
whismanoid 0:3edb3708c8c5 1385 #if HAS_pwmDriver9
whismanoid 0:3edb3708c8c5 1386 PwmOut pwmDriver9(P3_3); // P3_3 PT11 TARGET_MAX32630 J3.9 pass ok; conflict PT11 P3_3 P5_3
whismanoid 0:3edb3708c8c5 1387 #endif
whismanoid 0:3edb3708c8c5 1388 #if HAS_pwmDriver10
whismanoid 0:3edb3708c8c5 1389 PwmOut pwmDriver10(P3_2); // P3_2 PT10 TARGET_MAX32630 J3.10 pass ok; conflict PT10 P3_2 P5_2
whismanoid 0:3edb3708c8c5 1390 #endif
whismanoid 0:3edb3708c8c5 1391 #if HAS_pwmDriver11
whismanoid 0:3edb3708c8c5 1392 PwmOut pwmDriver11(P3_5); // P3_5 PT13 TARGET_MAX32630 J3.11 pass ok; conflict PT13 P3_5 P5_5
whismanoid 0:3edb3708c8c5 1393 #endif
whismanoid 0:3edb3708c8c5 1394 #if HAS_pwmDriver12
whismanoid 0:3edb3708c8c5 1395 PwmOut pwmDriver12(P3_4); // P3_4 PT12 TARGET_MAX32630 J3.12 pass ok; conflict PT12 P3_4 P5_4
whismanoid 0:3edb3708c8c5 1396 #endif
whismanoid 0:3edb3708c8c5 1397 #if HAS_pwmDriver13
whismanoid 0:3edb3708c8c5 1398 PwmOut pwmDriver13(P5_0); // P5_0 PT8 TARGET_MAX32630 J1.11 pass ok; conflict PT8 P3_0 P5_0
whismanoid 0:3edb3708c8c5 1399 #endif
whismanoid 0:3edb3708c8c5 1400 #if HAS_pwmDriver14
whismanoid 0:3edb3708c8c5 1401 PwmOut pwmDriver14(P5_1); // P5_1 PT9 TARGET_MAX32630 J1.12 pass ok; conflict PT9 P3_1 P5_1
whismanoid 0:3edb3708c8c5 1402 #endif
whismanoid 0:3edb3708c8c5 1403 #if HAS_pwmDriver15
whismanoid 0:3edb3708c8c5 1404 PwmOut pwmDriver15(____); // not assigned
whismanoid 0:3edb3708c8c5 1405 #endif
whismanoid 0:3edb3708c8c5 1406 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 1407 #elif defined(TARGET_MAX32625MBED)
whismanoid 0:3edb3708c8c5 1408 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 1409 // TODO1: pwmDriver TARGET=MAX32625MBED ARM Cortex-M4F 96MHz 512kB Flash 160kB SRAM
whismanoid 0:3edb3708c8c5 1410 #elif defined(TARGET_LPC1768)
whismanoid 0:3edb3708c8c5 1411 // TARGET=LPC1768 ARM Cortex-M3 100 MHz 512kB flash 64kB SRAM
whismanoid 0:3edb3708c8c5 1412 // +-------------[microUSB]-------------+
whismanoid 0:3edb3708c8c5 1413 // ______ | [ ] GND +3.3V VOUT [ ] |
whismanoid 0:3edb3708c8c5 1414 // ______ | [ ] 4.5V<VIN<9.0V +5.0V VU [ ] |
whismanoid 0:3edb3708c8c5 1415 // ______ | [ ] VB USB.IF- [ ] |
whismanoid 0:3edb3708c8c5 1416 // ______ | [ ] nR USB.IF+ [ ] |
whismanoid 0:3edb3708c8c5 1417 // ______ | [ ] p5 MOSI ETHERNET.RD- [ ] |
whismanoid 0:3edb3708c8c5 1418 // ______ | [ ] p6 MISO ETHERNET.RD+ [ ] |
whismanoid 0:3edb3708c8c5 1419 // ______ | [ ] p7 SCLK ETHERNET.TD- [ ] |
whismanoid 0:3edb3708c8c5 1420 // ______ | [ ] p8 ETHERNET.TD+ [ ] |
whismanoid 0:3edb3708c8c5 1421 // ______ | [ ] p9 TX SDA USB.D- [ ] |
whismanoid 0:3edb3708c8c5 1422 // ______ | [ ] p10 RX SCL USB.D+ [ ] |
whismanoid 0:3edb3708c8c5 1423 // ______ | [ ] p11 MOSI CAN-RD p30 [ ] |
whismanoid 0:3edb3708c8c5 1424 // ______ | [ ] p12 MISO CAN-TD p29 [ ] |
whismanoid 0:3edb3708c8c5 1425 // ______ | [ ] p13 TX SCLK SDA TX p28 [ ] |
whismanoid 0:3edb3708c8c5 1426 // ______ | [ ] p14 RX SCL RX p27 [ ] |
whismanoid 0:3edb3708c8c5 1427 // ______ | [ ] p15 AIN0 3.3Vfs PWM1 p26 [ ] | pwmDriver1
whismanoid 0:3edb3708c8c5 1428 // ______ | [ ] p16 AIN1 3.3Vfs PWM2 p25 [ ] | pwmDriver2
whismanoid 0:3edb3708c8c5 1429 // ______ | [ ] p17 AIN2 3.3Vfs PWM3 p24 [ ] | pwmDriver3
whismanoid 0:3edb3708c8c5 1430 // ______ | [ ] p18 AIN3 AOUT PWM4 p23 [ ] | pwmDriver4
whismanoid 0:3edb3708c8c5 1431 // ______ | [ ] p19 AIN4 3.3Vfs PWM5 p22 [ ] | pwmDriver5
whismanoid 0:3edb3708c8c5 1432 // ______ | [ ] p20 AIN5 3.3Vfs PWM6 p21 [ ] | pwmDriver6
whismanoid 0:3edb3708c8c5 1433 // +------------------------------------+
whismanoid 0:3edb3708c8c5 1434 // #define HAS_pwmDriver0 1
whismanoid 0:3edb3708c8c5 1435 # ifndef HAS_pwmDriver1
whismanoid 0:3edb3708c8c5 1436 #define HAS_pwmDriver1 1
whismanoid 0:3edb3708c8c5 1437 # endif
whismanoid 0:3edb3708c8c5 1438 # ifndef HAS_pwmDriver2
whismanoid 0:3edb3708c8c5 1439 #define HAS_pwmDriver2 1
whismanoid 0:3edb3708c8c5 1440 # endif
whismanoid 0:3edb3708c8c5 1441 # ifndef HAS_pwmDriver3
whismanoid 0:3edb3708c8c5 1442 #define HAS_pwmDriver3 1
whismanoid 0:3edb3708c8c5 1443 # endif
whismanoid 0:3edb3708c8c5 1444 # ifndef HAS_pwmDriver4
whismanoid 0:3edb3708c8c5 1445 #define HAS_pwmDriver4 1
whismanoid 0:3edb3708c8c5 1446 # endif
whismanoid 0:3edb3708c8c5 1447 # ifndef HAS_pwmDriver5
whismanoid 0:3edb3708c8c5 1448 #define HAS_pwmDriver5 1
whismanoid 0:3edb3708c8c5 1449 # endif
whismanoid 0:3edb3708c8c5 1450 # ifndef HAS_pwmDriver6
whismanoid 0:3edb3708c8c5 1451 #define HAS_pwmDriver6 1
whismanoid 0:3edb3708c8c5 1452 # endif
whismanoid 0:3edb3708c8c5 1453 # ifndef HAS_pwmDriver7
whismanoid 0:3edb3708c8c5 1454 // #define HAS_pwmDriver7 1
whismanoid 0:3edb3708c8c5 1455 # endif
whismanoid 0:3edb3708c8c5 1456 # ifndef HAS_pwmDriver8
whismanoid 0:3edb3708c8c5 1457 // #define HAS_pwmDriver8 1
whismanoid 0:3edb3708c8c5 1458 # endif
whismanoid 0:3edb3708c8c5 1459 # ifndef HAS_pwmDriver9
whismanoid 0:3edb3708c8c5 1460 // #define HAS_pwmDriver9 1
whismanoid 0:3edb3708c8c5 1461 # endif
whismanoid 0:3edb3708c8c5 1462 # ifndef HAS_pwmDriver10
whismanoid 0:3edb3708c8c5 1463 // #define HAS_pwmDriver10 1
whismanoid 0:3edb3708c8c5 1464 # endif
whismanoid 0:3edb3708c8c5 1465 # ifndef HAS_pwmDriver11
whismanoid 0:3edb3708c8c5 1466 // #define HAS_pwmDriver11 1
whismanoid 0:3edb3708c8c5 1467 # endif
whismanoid 0:3edb3708c8c5 1468 # ifndef HAS_pwmDriver12
whismanoid 0:3edb3708c8c5 1469 // #define HAS_pwmDriver12 1
whismanoid 0:3edb3708c8c5 1470 # endif
whismanoid 0:3edb3708c8c5 1471 # ifndef HAS_pwmDriver13
whismanoid 0:3edb3708c8c5 1472 // #define HAS_pwmDriver13 1
whismanoid 0:3edb3708c8c5 1473 # endif
whismanoid 0:3edb3708c8c5 1474 # ifndef HAS_pwmDriver14
whismanoid 0:3edb3708c8c5 1475 // #define HAS_pwmDriver14 1
whismanoid 0:3edb3708c8c5 1476 # endif
whismanoid 0:3edb3708c8c5 1477 # ifndef HAS_pwmDriver15
whismanoid 0:3edb3708c8c5 1478 // #define HAS_pwmDriver15 1
whismanoid 0:3edb3708c8c5 1479 # endif
whismanoid 0:3edb3708c8c5 1480 #if HAS_pwmDriver0
whismanoid 0:3edb3708c8c5 1481 PwmOut pwmDriver0(____); // not assigned
whismanoid 0:3edb3708c8c5 1482 #endif
whismanoid 0:3edb3708c8c5 1483 #if HAS_pwmDriver1
whismanoid 0:3edb3708c8c5 1484 PwmOut pwmDriver1(p26); // TARGET_LPC1768 P2.0/PWM1.1/TXD1/TRACECLK
whismanoid 0:3edb3708c8c5 1485 #endif
whismanoid 0:3edb3708c8c5 1486 #if HAS_pwmDriver2
whismanoid 0:3edb3708c8c5 1487 PwmOut pwmDriver2(p25); // TARGET_LPC1768 P2.1/PWM1.2/RXD1
whismanoid 0:3edb3708c8c5 1488 #endif
whismanoid 0:3edb3708c8c5 1489 #if HAS_pwmDriver3
whismanoid 0:3edb3708c8c5 1490 PwmOut pwmDriver3(p24); // TARGET_LPC1768 P2.2/PWM1.3/CTS1/TRACEDATA3
whismanoid 0:3edb3708c8c5 1491 #endif
whismanoid 0:3edb3708c8c5 1492 #if HAS_pwmDriver4
whismanoid 0:3edb3708c8c5 1493 PwmOut pwmDriver4(p23); // TARGET_LPC1768 P2.3/PWM1.4/DCD1/TRACEDATA2
whismanoid 0:3edb3708c8c5 1494 #endif
whismanoid 0:3edb3708c8c5 1495 #if HAS_pwmDriver5
whismanoid 0:3edb3708c8c5 1496 PwmOut pwmDriver5(p22); // TARGET_LPC1768 P2.4/PWM1.5/DSR1/TRACEDATA1
whismanoid 0:3edb3708c8c5 1497 #endif
whismanoid 0:3edb3708c8c5 1498 #if HAS_pwmDriver6
whismanoid 0:3edb3708c8c5 1499 PwmOut pwmDriver6(p21); // TARGET_LPC1768 P2.5/PWM1.6/DTR1/TRACEDATA0
whismanoid 0:3edb3708c8c5 1500 #endif
whismanoid 0:3edb3708c8c5 1501 #if HAS_pwmDriver7
whismanoid 0:3edb3708c8c5 1502 PwmOut pwmDriver7(____); // not assigned
whismanoid 0:3edb3708c8c5 1503 #endif
whismanoid 0:3edb3708c8c5 1504 #if HAS_pwmDriver8
whismanoid 0:3edb3708c8c5 1505 PwmOut pwmDriver8(____); // not assigned
whismanoid 0:3edb3708c8c5 1506 #endif
whismanoid 0:3edb3708c8c5 1507 #if HAS_pwmDriver9
whismanoid 0:3edb3708c8c5 1508 PwmOut pwmDriver9(____); // not assigned
whismanoid 0:3edb3708c8c5 1509 #endif
whismanoid 0:3edb3708c8c5 1510 #if HAS_pwmDriver10
whismanoid 0:3edb3708c8c5 1511 PwmOut pwmDriver10(____); // not assigned
whismanoid 0:3edb3708c8c5 1512 #endif
whismanoid 0:3edb3708c8c5 1513 #if HAS_pwmDriver11
whismanoid 0:3edb3708c8c5 1514 PwmOut pwmDriver11(____); // not assigned
whismanoid 0:3edb3708c8c5 1515 #endif
whismanoid 0:3edb3708c8c5 1516 #if HAS_pwmDriver12
whismanoid 0:3edb3708c8c5 1517 PwmOut pwmDriver12(____); // not assigned
whismanoid 0:3edb3708c8c5 1518 #endif
whismanoid 0:3edb3708c8c5 1519 #if HAS_pwmDriver13
whismanoid 0:3edb3708c8c5 1520 PwmOut pwmDriver13(____); // not assigned
whismanoid 0:3edb3708c8c5 1521 #endif
whismanoid 0:3edb3708c8c5 1522 #if HAS_pwmDriver14
whismanoid 0:3edb3708c8c5 1523 PwmOut pwmDriver14(____); // not assigned
whismanoid 0:3edb3708c8c5 1524 #endif
whismanoid 0:3edb3708c8c5 1525 #if HAS_pwmDriver15
whismanoid 0:3edb3708c8c5 1526 PwmOut pwmDriver15(____); // not assigned
whismanoid 0:3edb3708c8c5 1527 #endif
whismanoid 0:3edb3708c8c5 1528 #else
whismanoid 0:3edb3708c8c5 1529 // unknown target
whismanoid 0:3edb3708c8c5 1530 #endif
whismanoid 0:3edb3708c8c5 1531 // uncrustify-0.66.1 *INDENT-ON*
whismanoid 0:3edb3708c8c5 1532 #if HAS_pwmDriver0 || HAS_pwmDriver1 \
whismanoid 0:3edb3708c8c5 1533 || HAS_pwmDriver2 || HAS_pwmDriver3 \
whismanoid 0:3edb3708c8c5 1534 || HAS_pwmDriver4 || HAS_pwmDriver5 \
whismanoid 0:3edb3708c8c5 1535 || HAS_pwmDriver6 || HAS_pwmDriver7 \
whismanoid 0:3edb3708c8c5 1536 || HAS_pwmDriver8 || HAS_pwmDriver9 \
whismanoid 0:3edb3708c8c5 1537 || HAS_pwmDriver10 || HAS_pwmDriver11 \
whismanoid 0:3edb3708c8c5 1538 || HAS_pwmDriver12 || HAS_pwmDriver13 \
whismanoid 0:3edb3708c8c5 1539 || HAS_pwmDriver14 || HAS_pwmDriver15
whismanoid 0:3edb3708c8c5 1540 #define HAS_pwmDrivers 1
whismanoid 0:3edb3708c8c5 1541 #endif
whismanoid 0:3edb3708c8c5 1542
whismanoid 0:3edb3708c8c5 1543 // uncrustify-0.66.1 *INDENT-OFF*
whismanoid 0:3edb3708c8c5 1544 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 1545 // Declare the AnalogIn driver
whismanoid 0:3edb3708c8c5 1546 // Optional analogIn support. If there is only one it should be analogIn1.
whismanoid 0:3edb3708c8c5 1547 // A) analog input
whismanoid 0:3edb3708c8c5 1548 #if defined(TARGET_MAX32630)
whismanoid 0:3edb3708c8c5 1549 #define HAS_analogIn0 1
whismanoid 0:3edb3708c8c5 1550 #define HAS_analogIn1 1
whismanoid 0:3edb3708c8c5 1551 #define HAS_analogIn2 1
whismanoid 0:3edb3708c8c5 1552 #define HAS_analogIn3 1
whismanoid 0:3edb3708c8c5 1553 #define HAS_analogIn4 1
whismanoid 0:3edb3708c8c5 1554 #define HAS_analogIn5 1
whismanoid 0:3edb3708c8c5 1555 #define HAS_analogIn6 1
whismanoid 0:3edb3708c8c5 1556 #define HAS_analogIn7 1
whismanoid 0:3edb3708c8c5 1557 #define HAS_analogIn8 1
whismanoid 0:3edb3708c8c5 1558 #define HAS_analogIn9 1
whismanoid 0:3edb3708c8c5 1559 // #define HAS_analogIn10 0
whismanoid 0:3edb3708c8c5 1560 // #define HAS_analogIn11 0
whismanoid 0:3edb3708c8c5 1561 // #define HAS_analogIn12 0
whismanoid 0:3edb3708c8c5 1562 // #define HAS_analogIn13 0
whismanoid 0:3edb3708c8c5 1563 // #define HAS_analogIn14 0
whismanoid 0:3edb3708c8c5 1564 // #define HAS_analogIn15 0
whismanoid 0:3edb3708c8c5 1565 #if HAS_analogIn0
whismanoid 0:3edb3708c8c5 1566 AnalogIn analogIn0(AIN_0); // TARGET_MAX32630 J1.5 AIN_0 = AIN0 pin fullscale is 1.2V
whismanoid 0:3edb3708c8c5 1567 #endif
whismanoid 0:3edb3708c8c5 1568 #if HAS_analogIn1
whismanoid 0:3edb3708c8c5 1569 AnalogIn analogIn1(AIN_1); // TARGET_MAX32630 J1.6 AIN_1 = AIN1 pin fullscale is 1.2V
whismanoid 0:3edb3708c8c5 1570 #endif
whismanoid 0:3edb3708c8c5 1571 #if HAS_analogIn2
whismanoid 0:3edb3708c8c5 1572 AnalogIn analogIn2(AIN_2); // TARGET_MAX32630 J1.7 AIN_2 = AIN2 pin fullscale is 1.2V
whismanoid 0:3edb3708c8c5 1573 #endif
whismanoid 0:3edb3708c8c5 1574 #if HAS_analogIn3
whismanoid 0:3edb3708c8c5 1575 AnalogIn analogIn3(AIN_3); // TARGET_MAX32630 J1.8 AIN_3 = AIN3 pin fullscale is 1.2V
whismanoid 0:3edb3708c8c5 1576 #endif
whismanoid 0:3edb3708c8c5 1577 #if HAS_analogIn4
whismanoid 0:3edb3708c8c5 1578 AnalogIn analogIn4(AIN_4); // TARGET_MAX32630 J1.5 AIN_4 = AIN0 / 5.0 fullscale is 6.0V
whismanoid 0:3edb3708c8c5 1579 #endif
whismanoid 0:3edb3708c8c5 1580 #if HAS_analogIn5
whismanoid 0:3edb3708c8c5 1581 AnalogIn analogIn5(AIN_5); // TARGET_MAX32630 J1.6 AIN_5 = AIN1 / 5.0 fullscale is 6.0V
whismanoid 0:3edb3708c8c5 1582 #endif
whismanoid 0:3edb3708c8c5 1583 #if HAS_analogIn6
whismanoid 0:3edb3708c8c5 1584 AnalogIn analogIn6(AIN_6); // TARGET_MAX32630 AIN_6 = VDDB / 4.0 fullscale is 4.8V
whismanoid 0:3edb3708c8c5 1585 #endif
whismanoid 0:3edb3708c8c5 1586 #if HAS_analogIn7
whismanoid 0:3edb3708c8c5 1587 AnalogIn analogIn7(AIN_7); // TARGET_MAX32630 AIN_7 = VDD18 fullscale is 1.2V
whismanoid 0:3edb3708c8c5 1588 #endif
whismanoid 0:3edb3708c8c5 1589 #if HAS_analogIn8
whismanoid 0:3edb3708c8c5 1590 AnalogIn analogIn8(AIN_8); // TARGET_MAX32630 AIN_8 = VDD12 fullscale is 1.2V
whismanoid 0:3edb3708c8c5 1591 #endif
whismanoid 0:3edb3708c8c5 1592 #if HAS_analogIn9
whismanoid 0:3edb3708c8c5 1593 AnalogIn analogIn9(AIN_9); // TARGET_MAX32630 AIN_9 = VRTC / 2.0 fullscale is 2.4V
whismanoid 0:3edb3708c8c5 1594 #endif
whismanoid 0:3edb3708c8c5 1595 #if HAS_analogIn10
whismanoid 0:3edb3708c8c5 1596 AnalogIn analogIn10(____); // TARGET_MAX32630 AIN_10 = x undefined?
whismanoid 0:3edb3708c8c5 1597 #endif
whismanoid 0:3edb3708c8c5 1598 #if HAS_analogIn11
whismanoid 0:3edb3708c8c5 1599 AnalogIn analogIn11(____); // TARGET_MAX32630 AIN_11 = VDDIO / 4.0 fullscale is 4.8V
whismanoid 0:3edb3708c8c5 1600 #endif
whismanoid 0:3edb3708c8c5 1601 #if HAS_analogIn12
whismanoid 0:3edb3708c8c5 1602 AnalogIn analogIn12(____); // TARGET_MAX32630 AIN_12 = VDDIOH / 4.0 fullscale is 4.8V
whismanoid 0:3edb3708c8c5 1603 #endif
whismanoid 0:3edb3708c8c5 1604 #if HAS_analogIn13
whismanoid 0:3edb3708c8c5 1605 AnalogIn analogIn13(____);
whismanoid 0:3edb3708c8c5 1606 #endif
whismanoid 0:3edb3708c8c5 1607 #if HAS_analogIn14
whismanoid 0:3edb3708c8c5 1608 AnalogIn analogIn14(____);
whismanoid 0:3edb3708c8c5 1609 #endif
whismanoid 0:3edb3708c8c5 1610 #if HAS_analogIn15
whismanoid 0:3edb3708c8c5 1611 AnalogIn analogIn15(____);
whismanoid 0:3edb3708c8c5 1612 #endif
whismanoid 0:3edb3708c8c5 1613 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 1614 #elif defined(TARGET_MAX32625MBED)
whismanoid 0:3edb3708c8c5 1615 #define HAS_analogIn0 1
whismanoid 0:3edb3708c8c5 1616 #define HAS_analogIn1 1
whismanoid 0:3edb3708c8c5 1617 #define HAS_analogIn2 1
whismanoid 0:3edb3708c8c5 1618 #define HAS_analogIn3 1
whismanoid 0:3edb3708c8c5 1619 #define HAS_analogIn4 1
whismanoid 0:3edb3708c8c5 1620 #define HAS_analogIn5 1
whismanoid 0:3edb3708c8c5 1621 #if HAS_analogIn0
whismanoid 0:3edb3708c8c5 1622 AnalogIn analogIn0(AIN_0); // TARGET_MAX32630 J1.5 AIN_0 = AIN0 pin fullscale is 1.2V
whismanoid 0:3edb3708c8c5 1623 #endif
whismanoid 0:3edb3708c8c5 1624 #if HAS_analogIn1
whismanoid 0:3edb3708c8c5 1625 AnalogIn analogIn1(AIN_1); // TARGET_MAX32630 J1.6 AIN_1 = AIN1 pin fullscale is 1.2V
whismanoid 0:3edb3708c8c5 1626 #endif
whismanoid 0:3edb3708c8c5 1627 #if HAS_analogIn2
whismanoid 0:3edb3708c8c5 1628 AnalogIn analogIn2(AIN_2); // TARGET_MAX32630 J1.7 AIN_2 = AIN2 pin fullscale is 1.2V
whismanoid 0:3edb3708c8c5 1629 #endif
whismanoid 0:3edb3708c8c5 1630 #if HAS_analogIn3
whismanoid 0:3edb3708c8c5 1631 AnalogIn analogIn3(AIN_3); // TARGET_MAX32630 J1.8 AIN_3 = AIN3 pin fullscale is 1.2V
whismanoid 0:3edb3708c8c5 1632 #endif
whismanoid 0:3edb3708c8c5 1633 #if HAS_analogIn4
whismanoid 0:3edb3708c8c5 1634 AnalogIn analogIn4(AIN_4); // TARGET_MAX32630 J1.5 AIN_4 = AIN0 / 5.0 fullscale is 6.0V
whismanoid 0:3edb3708c8c5 1635 #endif
whismanoid 0:3edb3708c8c5 1636 #if HAS_analogIn5
whismanoid 0:3edb3708c8c5 1637 AnalogIn analogIn5(AIN_5); // TARGET_MAX32630 J1.6 AIN_5 = AIN1 / 5.0 fullscale is 6.0V
whismanoid 0:3edb3708c8c5 1638 #endif
whismanoid 0:3edb3708c8c5 1639 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 1640 #elif defined(TARGET_NUCLEO_F446RE)
whismanoid 0:3edb3708c8c5 1641 #define HAS_analogIn0 1
whismanoid 0:3edb3708c8c5 1642 #define HAS_analogIn1 1
whismanoid 0:3edb3708c8c5 1643 #define HAS_analogIn2 1
whismanoid 0:3edb3708c8c5 1644 #define HAS_analogIn3 1
whismanoid 0:3edb3708c8c5 1645 #define HAS_analogIn4 1
whismanoid 0:3edb3708c8c5 1646 #define HAS_analogIn5 1
whismanoid 0:3edb3708c8c5 1647 #if HAS_analogIn0
whismanoid 0:3edb3708c8c5 1648 AnalogIn analogIn0(A0);
whismanoid 0:3edb3708c8c5 1649 #endif
whismanoid 0:3edb3708c8c5 1650 #if HAS_analogIn1
whismanoid 0:3edb3708c8c5 1651 AnalogIn analogIn1(A1);
whismanoid 0:3edb3708c8c5 1652 #endif
whismanoid 0:3edb3708c8c5 1653 #if HAS_analogIn2
whismanoid 0:3edb3708c8c5 1654 AnalogIn analogIn2(A2);
whismanoid 0:3edb3708c8c5 1655 #endif
whismanoid 0:3edb3708c8c5 1656 #if HAS_analogIn3
whismanoid 0:3edb3708c8c5 1657 AnalogIn analogIn3(A3);
whismanoid 0:3edb3708c8c5 1658 #endif
whismanoid 0:3edb3708c8c5 1659 #if HAS_analogIn4
whismanoid 0:3edb3708c8c5 1660 AnalogIn analogIn4(A4);
whismanoid 0:3edb3708c8c5 1661 #endif
whismanoid 0:3edb3708c8c5 1662 #if HAS_analogIn5
whismanoid 0:3edb3708c8c5 1663 AnalogIn analogIn5(A5);
whismanoid 0:3edb3708c8c5 1664 #endif
whismanoid 0:3edb3708c8c5 1665 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 1666 #elif defined(TARGET_NUCLEO_F401RE)
whismanoid 0:3edb3708c8c5 1667 #define HAS_analogIn0 1
whismanoid 0:3edb3708c8c5 1668 #define HAS_analogIn1 1
whismanoid 0:3edb3708c8c5 1669 #define HAS_analogIn2 1
whismanoid 0:3edb3708c8c5 1670 #define HAS_analogIn3 1
whismanoid 0:3edb3708c8c5 1671 #define HAS_analogIn4 1
whismanoid 0:3edb3708c8c5 1672 #define HAS_analogIn5 1
whismanoid 0:3edb3708c8c5 1673 #if HAS_analogIn0
whismanoid 0:3edb3708c8c5 1674 AnalogIn analogIn0(A0);
whismanoid 0:3edb3708c8c5 1675 #endif
whismanoid 0:3edb3708c8c5 1676 #if HAS_analogIn1
whismanoid 0:3edb3708c8c5 1677 AnalogIn analogIn1(A1);
whismanoid 0:3edb3708c8c5 1678 #endif
whismanoid 0:3edb3708c8c5 1679 #if HAS_analogIn2
whismanoid 0:3edb3708c8c5 1680 AnalogIn analogIn2(A2);
whismanoid 0:3edb3708c8c5 1681 #endif
whismanoid 0:3edb3708c8c5 1682 #if HAS_analogIn3
whismanoid 0:3edb3708c8c5 1683 AnalogIn analogIn3(A3);
whismanoid 0:3edb3708c8c5 1684 #endif
whismanoid 0:3edb3708c8c5 1685 #if HAS_analogIn4
whismanoid 0:3edb3708c8c5 1686 AnalogIn analogIn4(A4);
whismanoid 0:3edb3708c8c5 1687 #endif
whismanoid 0:3edb3708c8c5 1688 #if HAS_analogIn5
whismanoid 0:3edb3708c8c5 1689 AnalogIn analogIn5(A5);
whismanoid 0:3edb3708c8c5 1690 #endif
whismanoid 0:3edb3708c8c5 1691 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 1692 // TODO1: TARGET=MAX32625MBED ARM Cortex-M4F 96MHz 512kB Flash 160kB SRAM
whismanoid 0:3edb3708c8c5 1693 #elif defined(TARGET_LPC1768)
whismanoid 0:3edb3708c8c5 1694 #define HAS_analogIn0 1
whismanoid 0:3edb3708c8c5 1695 #define HAS_analogIn1 1
whismanoid 0:3edb3708c8c5 1696 #define HAS_analogIn2 1
whismanoid 0:3edb3708c8c5 1697 #define HAS_analogIn3 1
whismanoid 0:3edb3708c8c5 1698 #define HAS_analogIn4 1
whismanoid 0:3edb3708c8c5 1699 #define HAS_analogIn5 1
whismanoid 0:3edb3708c8c5 1700 // #define HAS_analogIn6 1
whismanoid 0:3edb3708c8c5 1701 // #define HAS_analogIn7 1
whismanoid 0:3edb3708c8c5 1702 // #define HAS_analogIn8 1
whismanoid 0:3edb3708c8c5 1703 // #define HAS_analogIn9 1
whismanoid 0:3edb3708c8c5 1704 // #define HAS_analogIn10 1
whismanoid 0:3edb3708c8c5 1705 // #define HAS_analogIn11 1
whismanoid 0:3edb3708c8c5 1706 // #define HAS_analogIn12 1
whismanoid 0:3edb3708c8c5 1707 // #define HAS_analogIn13 1
whismanoid 0:3edb3708c8c5 1708 // #define HAS_analogIn14 1
whismanoid 0:3edb3708c8c5 1709 // #define HAS_analogIn15 1
whismanoid 0:3edb3708c8c5 1710 #if HAS_analogIn0
whismanoid 0:3edb3708c8c5 1711 AnalogIn analogIn0(p15); // TARGET_LPC1768 P0.23/AD0.0/I2SRX_CLK/CAP3.0
whismanoid 0:3edb3708c8c5 1712 #endif
whismanoid 0:3edb3708c8c5 1713 #if HAS_analogIn1
whismanoid 0:3edb3708c8c5 1714 AnalogIn analogIn1(p16); // TARGET_LPC1768 P0.24/AD0.1/I2SRX_WS/CAP3.1
whismanoid 0:3edb3708c8c5 1715 #endif
whismanoid 0:3edb3708c8c5 1716 #if HAS_analogIn2
whismanoid 0:3edb3708c8c5 1717 AnalogIn analogIn2(p17); // TARGET_LPC1768 P0.25/AD0.2/I2SRX_SDA/TXD3
whismanoid 0:3edb3708c8c5 1718 #endif
whismanoid 0:3edb3708c8c5 1719 #if HAS_analogIn3
whismanoid 0:3edb3708c8c5 1720 AnalogIn analogIn3(p18); // TARGET_LPC1768 P0.26/AD0.3/AOUT/RXD3
whismanoid 0:3edb3708c8c5 1721 #endif
whismanoid 0:3edb3708c8c5 1722 #if HAS_analogIn4
whismanoid 0:3edb3708c8c5 1723 AnalogIn analogIn4(p19); // TARGET_LPC1768 P1.30/VBUS/AD0.4
whismanoid 0:3edb3708c8c5 1724 #endif
whismanoid 0:3edb3708c8c5 1725 #if HAS_analogIn5
whismanoid 0:3edb3708c8c5 1726 AnalogIn analogIn5(p20); // TARGET_LPC1768 P1.31/SCK1/AD0.5
whismanoid 0:3edb3708c8c5 1727 #endif
whismanoid 0:3edb3708c8c5 1728 #if HAS_analogIn6
whismanoid 0:3edb3708c8c5 1729 AnalogIn analogIn6(____);
whismanoid 0:3edb3708c8c5 1730 #endif
whismanoid 0:3edb3708c8c5 1731 #if HAS_analogIn7
whismanoid 0:3edb3708c8c5 1732 AnalogIn analogIn7(____);
whismanoid 0:3edb3708c8c5 1733 #endif
whismanoid 0:3edb3708c8c5 1734 #if HAS_analogIn8
whismanoid 0:3edb3708c8c5 1735 AnalogIn analogIn8(____);
whismanoid 0:3edb3708c8c5 1736 #endif
whismanoid 0:3edb3708c8c5 1737 #if HAS_analogIn9
whismanoid 0:3edb3708c8c5 1738 AnalogIn analogIn9(____);
whismanoid 0:3edb3708c8c5 1739 #endif
whismanoid 0:3edb3708c8c5 1740 #if HAS_analogIn10
whismanoid 0:3edb3708c8c5 1741 AnalogIn analogIn10(____);
whismanoid 0:3edb3708c8c5 1742 #endif
whismanoid 0:3edb3708c8c5 1743 #if HAS_analogIn11
whismanoid 0:3edb3708c8c5 1744 AnalogIn analogIn11(____);
whismanoid 0:3edb3708c8c5 1745 #endif
whismanoid 0:3edb3708c8c5 1746 #if HAS_analogIn12
whismanoid 0:3edb3708c8c5 1747 AnalogIn analogIn12(____);
whismanoid 0:3edb3708c8c5 1748 #endif
whismanoid 0:3edb3708c8c5 1749 #if HAS_analogIn13
whismanoid 0:3edb3708c8c5 1750 AnalogIn analogIn13(____);
whismanoid 0:3edb3708c8c5 1751 #endif
whismanoid 0:3edb3708c8c5 1752 #if HAS_analogIn14
whismanoid 0:3edb3708c8c5 1753 AnalogIn analogIn14(____);
whismanoid 0:3edb3708c8c5 1754 #endif
whismanoid 0:3edb3708c8c5 1755 #if HAS_analogIn15
whismanoid 0:3edb3708c8c5 1756 AnalogIn analogIn15(____);
whismanoid 0:3edb3708c8c5 1757 #endif
whismanoid 0:3edb3708c8c5 1758 #else
whismanoid 0:3edb3708c8c5 1759 // unknown target
whismanoid 0:3edb3708c8c5 1760 #endif
whismanoid 0:3edb3708c8c5 1761 // uncrustify-0.66.1 *INDENT-ON*
whismanoid 0:3edb3708c8c5 1762 #if HAS_analogIn0 || HAS_analogIn1 \
whismanoid 0:3edb3708c8c5 1763 || HAS_analogIn2 || HAS_analogIn3 \
whismanoid 0:3edb3708c8c5 1764 || HAS_analogIn4 || HAS_analogIn5 \
whismanoid 0:3edb3708c8c5 1765 || HAS_analogIn6 || HAS_analogIn7 \
whismanoid 0:3edb3708c8c5 1766 || HAS_analogIn8 || HAS_analogIn9 \
whismanoid 0:3edb3708c8c5 1767 || HAS_analogIn10 || HAS_analogIn11 \
whismanoid 0:3edb3708c8c5 1768 || HAS_analogIn12 || HAS_analogIn13 \
whismanoid 0:3edb3708c8c5 1769 || HAS_analogIn14 || HAS_analogIn15
whismanoid 0:3edb3708c8c5 1770 #define HAS_analogIns 1
whismanoid 0:3edb3708c8c5 1771 #endif
whismanoid 0:3edb3708c8c5 1772
whismanoid 0:3edb3708c8c5 1773 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 1774 // Diagnostic: scope trigger
whismanoid 0:3edb3708c8c5 1775 //#define SCOPE_TRIG_PIN p11
whismanoid 0:3edb3708c8c5 1776 //#ifdef SCOPE_TRIG_PIN
whismanoid 0:3edb3708c8c5 1777 //# if defined(TARGET_MAX32630)
whismanoid 0:3edb3708c8c5 1778 // // TARGET=MAX32630
whismanoid 0:3edb3708c8c5 1779 // DigitalOut scopeTrigPinP11(P3_1, 1);
whismanoid 0:3edb3708c8c5 1780 // DigitalOut scopePinP12(P3_0, 1);
whismanoid 0:3edb3708c8c5 1781 //# elif defined(TARGET_LPC1768)
whismanoid 0:3edb3708c8c5 1782 // // TARGET=LPC1768
whismanoid 0:3edb3708c8c5 1783 // DigitalOut scopeTrigPinP11(p11, 1);
whismanoid 0:3edb3708c8c5 1784 // DigitalOut scopePinP12(p12, 1);
whismanoid 0:3edb3708c8c5 1785 //# else
whismanoid 0:3edb3708c8c5 1786 // // unknown target
whismanoid 0:3edb3708c8c5 1787 //# endif
whismanoid 0:3edb3708c8c5 1788 //#endif
whismanoid 0:3edb3708c8c5 1789
whismanoid 0:3edb3708c8c5 1790 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 1791 // Option to use LEDs to show status
whismanoid 0:3edb3708c8c5 1792 #ifndef USE_LEDS
whismanoid 0:3edb3708c8c5 1793 #define USE_LEDS 1
whismanoid 0:3edb3708c8c5 1794 #endif
whismanoid 0:3edb3708c8c5 1795 #if USE_LEDS
whismanoid 0:3edb3708c8c5 1796 #if defined(TARGET_MAX32630)
whismanoid 0:3edb3708c8c5 1797 # define LED_ON 0
whismanoid 0:3edb3708c8c5 1798 # define LED_OFF 1
whismanoid 0:3edb3708c8c5 1799 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 1800 #elif defined(TARGET_MAX32625MBED)
whismanoid 0:3edb3708c8c5 1801 # define LED_ON 0
whismanoid 0:3edb3708c8c5 1802 # define LED_OFF 1
whismanoid 0:3edb3708c8c5 1803 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 1804 // TODO1: TARGET=MAX32625MBED ARM Cortex-M4F 96MHz 512kB Flash 160kB SRAM
whismanoid 0:3edb3708c8c5 1805 #elif defined(TARGET_LPC1768)
whismanoid 0:3edb3708c8c5 1806 # define LED_ON 1
whismanoid 0:3edb3708c8c5 1807 # define LED_OFF 0
whismanoid 0:3edb3708c8c5 1808 #else // not defined(TARGET_LPC1768 etc.)
whismanoid 0:3edb3708c8c5 1809 # define LED_ON 1
whismanoid 0:3edb3708c8c5 1810 # define LED_OFF 0
whismanoid 0:3edb3708c8c5 1811 #endif // target definition
whismanoid 0:3edb3708c8c5 1812 DigitalOut led1(LED1, LED_OFF); // MAX32630FTHR: LED1 = LED_RED
whismanoid 0:3edb3708c8c5 1813 DigitalOut led2(LED2, LED_OFF); // MAX32630FTHR: LED2 = LED_GREEN
whismanoid 0:3edb3708c8c5 1814 DigitalOut led3(LED3, LED_OFF); // MAX32630FTHR: LED3 = LED_BLUE
whismanoid 0:3edb3708c8c5 1815 DigitalOut led4(LED4, LED_OFF);
whismanoid 0:3edb3708c8c5 1816 #endif // USE_LEDS
whismanoid 0:3edb3708c8c5 1817
whismanoid 0:3edb3708c8c5 1818 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 1819 #if USE_LEDS
whismanoid 0:3edb3708c8c5 1820 class RGB_LED {
whismanoid 0:3edb3708c8c5 1821 public:
whismanoid 0:3edb3708c8c5 1822 RGB_LED(DigitalOut &led_red, DigitalOut &led_green, DigitalOut &led_blue)
whismanoid 0:3edb3708c8c5 1823 : m_red(led_red), m_green(led_green), m_blue(led_blue)
whismanoid 0:3edb3708c8c5 1824 {
whismanoid 0:3edb3708c8c5 1825 };
whismanoid 0:3edb3708c8c5 1826 DigitalOut &m_red;
whismanoid 0:3edb3708c8c5 1827 DigitalOut &m_green;
whismanoid 0:3edb3708c8c5 1828 DigitalOut &m_blue;
whismanoid 0:3edb3708c8c5 1829 ~RGB_LED()
whismanoid 0:3edb3708c8c5 1830 {
whismanoid 0:3edb3708c8c5 1831 };
whismanoid 0:3edb3708c8c5 1832 /* diagnostic rbg led RED
whismanoid 0:3edb3708c8c5 1833 */
whismanoid 0:3edb3708c8c5 1834 void red() {
whismanoid 0:3edb3708c8c5 1835 m_red = LED_ON; m_green = LED_OFF; m_blue = LED_OFF; // diagnostic rbg led RED
whismanoid 0:3edb3708c8c5 1836 };
whismanoid 0:3edb3708c8c5 1837 /* diagnostic rbg led GREEN
whismanoid 0:3edb3708c8c5 1838 */
whismanoid 0:3edb3708c8c5 1839 void green() {
whismanoid 0:3edb3708c8c5 1840 m_red = LED_OFF; m_green = LED_ON; m_blue = LED_OFF; // diagnostic rbg led GREEN
whismanoid 0:3edb3708c8c5 1841 };
whismanoid 0:3edb3708c8c5 1842 /* diagnostic rbg led BLUE
whismanoid 0:3edb3708c8c5 1843 */
whismanoid 0:3edb3708c8c5 1844 void blue() {
whismanoid 0:3edb3708c8c5 1845 m_red = LED_OFF; m_green = LED_OFF; m_blue = LED_ON; // diagnostic rbg led BLUE
whismanoid 0:3edb3708c8c5 1846 };
whismanoid 0:3edb3708c8c5 1847 /* diagnostic rbg led RED+GREEN+BLUE=WHITE
whismanoid 0:3edb3708c8c5 1848 */
whismanoid 0:3edb3708c8c5 1849 void white() {
whismanoid 0:3edb3708c8c5 1850 m_red = LED_ON; m_green = LED_ON; m_blue = LED_ON; // diagnostic rbg led RED+GREEN+BLUE=WHITE
whismanoid 0:3edb3708c8c5 1851 };
whismanoid 0:3edb3708c8c5 1852 /* diagnostic rbg led GREEN+BLUE=CYAN
whismanoid 0:3edb3708c8c5 1853 */
whismanoid 0:3edb3708c8c5 1854 void cyan() {
whismanoid 0:3edb3708c8c5 1855 m_red = LED_OFF; m_green = LED_ON; m_blue = LED_ON; // diagnostic rbg led GREEN+BLUE=CYAN
whismanoid 0:3edb3708c8c5 1856 };
whismanoid 0:3edb3708c8c5 1857 /* diagnostic rbg led RED+BLUE=MAGENTA
whismanoid 0:3edb3708c8c5 1858 */
whismanoid 0:3edb3708c8c5 1859 void magenta() {
whismanoid 0:3edb3708c8c5 1860 m_red = LED_ON; m_green = LED_OFF; m_blue = LED_ON; // diagnostic rbg led RED+BLUE=MAGENTA
whismanoid 0:3edb3708c8c5 1861 };
whismanoid 0:3edb3708c8c5 1862 /* diagnostic rbg led RED+GREEN=YELLOW
whismanoid 0:3edb3708c8c5 1863 */
whismanoid 0:3edb3708c8c5 1864 void yellow() {
whismanoid 0:3edb3708c8c5 1865 m_red = LED_ON; m_green = LED_ON; m_blue = LED_OFF; // diagnostic rbg led RED+GREEN=YELLOW
whismanoid 0:3edb3708c8c5 1866 };
whismanoid 0:3edb3708c8c5 1867 /* diagnostic rbg led BLACK
whismanoid 0:3edb3708c8c5 1868 */
whismanoid 0:3edb3708c8c5 1869 void black() {
whismanoid 0:3edb3708c8c5 1870 m_red = LED_OFF; m_green = LED_OFF; m_blue = LED_OFF; // diagnostic rbg led BLACK
whismanoid 0:3edb3708c8c5 1871 };
whismanoid 0:3edb3708c8c5 1872 };
whismanoid 0:3edb3708c8c5 1873 RGB_LED rgb_led(led1, led2, led3); // red, green, blue LEDs
whismanoid 0:3edb3708c8c5 1874 #endif // USE_LEDS
whismanoid 0:3edb3708c8c5 1875
whismanoid 0:3edb3708c8c5 1876 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 1877 // use BUTTON1 trigger some action
whismanoid 0:3edb3708c8c5 1878 #if defined(TARGET_MAX32630)
whismanoid 0:3edb3708c8c5 1879 #define HAS_BUTTON1_DEMO_INTERRUPT 1
whismanoid 0:3edb3708c8c5 1880 #elif defined(TARGET_MAX32625)
whismanoid 0:3edb3708c8c5 1881 #define HAS_BUTTON1_DEMO_INTERRUPT 1
whismanoid 0:3edb3708c8c5 1882 #define HAS_BUTTON2_DEMO_INTERRUPT 1
whismanoid 0:3edb3708c8c5 1883 #elif defined(TARGET_NUCLEO_F446RE)
whismanoid 0:3edb3708c8c5 1884 #define HAS_BUTTON1_DEMO_INTERRUPT 0
whismanoid 0:3edb3708c8c5 1885 #define HAS_BUTTON2_DEMO_INTERRUPT 0
whismanoid 0:3edb3708c8c5 1886 #elif defined(TARGET_NUCLEO_F401RE)
whismanoid 0:3edb3708c8c5 1887 #define HAS_BUTTON1_DEMO_INTERRUPT 0
whismanoid 0:3edb3708c8c5 1888 #define HAS_BUTTON2_DEMO_INTERRUPT 0
whismanoid 0:3edb3708c8c5 1889 #endif
whismanoid 0:3edb3708c8c5 1890 //
whismanoid 0:3edb3708c8c5 1891 #ifndef HAS_BUTTON1_DEMO
whismanoid 0:3edb3708c8c5 1892 #define HAS_BUTTON1_DEMO 0
whismanoid 0:3edb3708c8c5 1893 #endif
whismanoid 0:3edb3708c8c5 1894 #ifndef HAS_BUTTON2_DEMO
whismanoid 0:3edb3708c8c5 1895 #define HAS_BUTTON2_DEMO 0
whismanoid 0:3edb3708c8c5 1896 #endif
whismanoid 0:3edb3708c8c5 1897 //
whismanoid 0:3edb3708c8c5 1898 // avoid runtime error on button1 press [mbed-os-5.11]
whismanoid 0:3edb3708c8c5 1899 // instead of using InterruptIn, use DigitalIn and poll in main while(1)
whismanoid 0:3edb3708c8c5 1900 #ifndef HAS_BUTTON1_DEMO_INTERRUPT_POLLING
whismanoid 0:3edb3708c8c5 1901 #define HAS_BUTTON1_DEMO_INTERRUPT_POLLING 1
whismanoid 0:3edb3708c8c5 1902 #endif
whismanoid 0:3edb3708c8c5 1903 //
whismanoid 0:3edb3708c8c5 1904 #ifndef HAS_BUTTON1_DEMO_INTERRUPT
whismanoid 0:3edb3708c8c5 1905 #define HAS_BUTTON1_DEMO_INTERRUPT 1
whismanoid 0:3edb3708c8c5 1906 #endif
whismanoid 0:3edb3708c8c5 1907 #ifndef HAS_BUTTON2_DEMO_INTERRUPT
whismanoid 0:3edb3708c8c5 1908 #define HAS_BUTTON2_DEMO_INTERRUPT 1
whismanoid 0:3edb3708c8c5 1909 #endif
whismanoid 0:3edb3708c8c5 1910 //
whismanoid 0:3edb3708c8c5 1911 #if HAS_BUTTON1_DEMO_INTERRUPT
whismanoid 0:3edb3708c8c5 1912 # if HAS_BUTTON1_DEMO_INTERRUPT_POLLING
whismanoid 0:3edb3708c8c5 1913 // avoid runtime error on button1 press [mbed-os-5.11]
whismanoid 0:3edb3708c8c5 1914 // instead of using InterruptIn, use DigitalIn and poll in main while(1)
whismanoid 0:3edb3708c8c5 1915 DigitalIn button1(BUTTON1);
whismanoid 0:3edb3708c8c5 1916 # else
whismanoid 0:3edb3708c8c5 1917 InterruptIn button1(BUTTON1);
whismanoid 0:3edb3708c8c5 1918 # endif
whismanoid 0:3edb3708c8c5 1919 #elif HAS_BUTTON1_DEMO
whismanoid 0:3edb3708c8c5 1920 DigitalIn button1(BUTTON1);
whismanoid 0:3edb3708c8c5 1921 #endif
whismanoid 0:3edb3708c8c5 1922 #if HAS_BUTTON2_DEMO_INTERRUPT
whismanoid 0:3edb3708c8c5 1923 # if HAS_BUTTON1_DEMO_INTERRUPT_POLLING
whismanoid 0:3edb3708c8c5 1924 // avoid runtime error on button1 press [mbed-os-5.11]
whismanoid 0:3edb3708c8c5 1925 // instead of using InterruptIn, use DigitalIn and poll in main while(1)
whismanoid 0:3edb3708c8c5 1926 DigitalIn button2(BUTTON2);
whismanoid 0:3edb3708c8c5 1927 # else
whismanoid 0:3edb3708c8c5 1928 InterruptIn button2(BUTTON2);
whismanoid 0:3edb3708c8c5 1929 # endif
whismanoid 0:3edb3708c8c5 1930 #elif HAS_BUTTON2_DEMO
whismanoid 0:3edb3708c8c5 1931 DigitalIn button2(BUTTON2);
whismanoid 0:3edb3708c8c5 1932 #endif
whismanoid 0:3edb3708c8c5 1933
whismanoid 0:3edb3708c8c5 1934 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 1935 // Ticker is the periodic interrupt timer itself
whismanoid 0:3edb3708c8c5 1936 #define USE_PERIODIC_TIMER 0
whismanoid 0:3edb3708c8c5 1937 #if USE_PERIODIC_TIMER
whismanoid 0:3edb3708c8c5 1938 Ticker periodicInterruptTimer;
whismanoid 0:3edb3708c8c5 1939 us_timestamp_t periodicInterruptTimer_interval_usec = 50;
whismanoid 0:3edb3708c8c5 1940 us_timestamp_t periodicInterruptTimer_interval_usec_MAX = 1000;
whismanoid 0:3edb3708c8c5 1941 us_timestamp_t periodicInterruptTimer_interval_usec_MIN = 20;
whismanoid 0:3edb3708c8c5 1942 #endif
whismanoid 0:3edb3708c8c5 1943
whismanoid 0:3edb3708c8c5 1944
whismanoid 0:3edb3708c8c5 1945 #if APPLICATION_MAX5715 // hardware interface functions
whismanoid 0:3edb3708c8c5 1946 //----------------------------------------
whismanoid 0:3edb3708c8c5 1947 // User-provided hardware function
whismanoid 0:3edb3708c8c5 1948 // declare user-provided hardware interface function drive MAX5717_LDACb_Pin LDAC#
whismanoid 0:3edb3708c8c5 1949 // drive LDAC# Active-Low Asynchronous Load DAC Input for MAX5715
whismanoid 0:3edb3708c8c5 1950 //
whismanoid 0:3edb3708c8c5 1951 //void GPIOoutputLDACb(int isLogicHigh)
whismanoid 0:3edb3708c8c5 1952 //{
whismanoid 0:3edb3708c8c5 1953 // digitalInOut9.output();
whismanoid 0:3edb3708c8c5 1954 // digitalInOut9.write(isLogicHigh);
whismanoid 0:3edb3708c8c5 1955 //
whismanoid 0:3edb3708c8c5 1956 //#if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 1957 // cmdLine_microUSBserial.serial().printf(" digitalInOutPin 9 Output %d ", isLogicHigh);
whismanoid 0:3edb3708c8c5 1958 //#endif
whismanoid 0:3edb3708c8c5 1959 //#if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 1960 // cmdLine_DAPLINKserial.serial().printf(" digitalInOutPin 9 Output %d ", isLogicHigh);
whismanoid 0:3edb3708c8c5 1961 //#endif
whismanoid 0:3edb3708c8c5 1962 //}
whismanoid 0:3edb3708c8c5 1963
whismanoid 0:3edb3708c8c5 1964 //----------------------------------------
whismanoid 0:3edb3708c8c5 1965 // User-provided hardware function
whismanoid 0:3edb3708c8c5 1966 // declare user-provided hardware interface function drive MAX5717_CLRb_Pin CLR#
whismanoid 0:3edb3708c8c5 1967 // drive CLR# Active-Low Clear Input for MAX5715
whismanoid 0:3edb3708c8c5 1968 //
whismanoid 0:3edb3708c8c5 1969 //void GPIOoutputCLRb(int isLogicHigh)
whismanoid 0:3edb3708c8c5 1970 //{
whismanoid 0:3edb3708c8c5 1971 // digitalInOut8.output();
whismanoid 0:3edb3708c8c5 1972 // digitalInOut8.write(isLogicHigh);
whismanoid 0:3edb3708c8c5 1973 //
whismanoid 0:3edb3708c8c5 1974 //#if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 1975 // cmdLine_microUSBserial.serial().printf(" digitalInOutPin 8 Output %d ", isLogicHigh);
whismanoid 0:3edb3708c8c5 1976 //#endif
whismanoid 0:3edb3708c8c5 1977 //#if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 1978 // cmdLine_DAPLINKserial.serial().printf(" digitalInOutPin 8 Output %d ", isLogicHigh);
whismanoid 0:3edb3708c8c5 1979 //#endif
whismanoid 0:3edb3708c8c5 1980 //}
whismanoid 0:3edb3708c8c5 1981 #endif
whismanoid 0:3edb3708c8c5 1982
whismanoid 0:3edb3708c8c5 1983
whismanoid 0:3edb3708c8c5 1984 #if APPLICATION_MAX11131 // hardware interface functions
whismanoid 0:3edb3708c8c5 1985 //----------------------------------------
whismanoid 0:3edb3708c8c5 1986 void print_value(CmdLine& cmdLine, int16_t value_u12, int channelId)
whismanoid 0:3edb3708c8c5 1987 {
whismanoid 0:3edb3708c8c5 1988 int channelPairIndex = channelId / 2;
whismanoid 0:3edb3708c8c5 1989 // format: 1 0 0 0 1 UCH0/1 UCH2/3 UCH4/5 UCH6/7 UCH8/9 UCH10/11 UCH12/13 UCH14/15 PDIFF_COM x x
whismanoid 0:3edb3708c8c5 1990 // unused variable: int UCHn = (g_MAX11131_device.UNIPOLAR >> (10 - channelPairIndex)) & 0x01;
whismanoid 0:3edb3708c8c5 1991 int BCHn = (g_MAX11131_device.BIPOLAR >> (10 - channelPairIndex)) & 0x01;
whismanoid 0:3edb3708c8c5 1992 // unused variable: int RANGEn = (g_MAX11131_device.RANGE >> (10 - channelPairIndex)) & 0x01;
whismanoid 0:3edb3708c8c5 1993 //
whismanoid 0:3edb3708c8c5 1994 cmdLine.serial().printf(" ch=");
whismanoid 0:3edb3708c8c5 1995 // TODO1: if CHANID=0 don't print ch=channelId
whismanoid 0:3edb3708c8c5 1996 if ((g_MAX11131_device.isExternalClock == 0) || (g_MAX11131_device.chan_id_0_1 == 1))
whismanoid 0:3edb3708c8c5 1997 {
whismanoid 0:3edb3708c8c5 1998 // Internal clock modes always use channel ID.
whismanoid 0:3edb3708c8c5 1999 // External clock modes use channel ID if ADC_MODE_CONTROL.CHAN_ID is 1.
whismanoid 0:3edb3708c8c5 2000 cmdLine.serial().printf("%d", channelId);
whismanoid 0:3edb3708c8c5 2001 } else {
whismanoid 0:3edb3708c8c5 2002 cmdLine.serial().printf("?");
whismanoid 0:3edb3708c8c5 2003 }
whismanoid 0:3edb3708c8c5 2004 if (BCHn)
whismanoid 0:3edb3708c8c5 2005 {
whismanoid 3:8913cb4a8b9f 2006 cmdLine.serial().printf(" xb=%ld", g_MAX11131_device.TwosComplementValue(value_u12));
whismanoid 0:3edb3708c8c5 2007 }
whismanoid 0:3edb3708c8c5 2008 else
whismanoid 0:3edb3708c8c5 2009 {
whismanoid 0:3edb3708c8c5 2010 cmdLine.serial().printf(" xu=%d", value_u12);
whismanoid 0:3edb3708c8c5 2011 }
whismanoid 0:3edb3708c8c5 2012 cmdLine.serial().printf(" = 0x%4.4x = %6.4fV",
whismanoid 0:3edb3708c8c5 2013 (value_u12 & 0xFFFF),
whismanoid 0:3edb3708c8c5 2014 g_MAX11131_device.VoltageOfCode(value_u12, channelId)
whismanoid 0:3edb3708c8c5 2015 );
whismanoid 0:3edb3708c8c5 2016 // dtostrf width and precision: 2.5v / 4096 LSB = 0.0006103515625 volts per LSB
whismanoid 0:3edb3708c8c5 2017 }
whismanoid 0:3edb3708c8c5 2018
whismanoid 0:3edb3708c8c5 2019 //----------------------------------------
whismanoid 0:3edb3708c8c5 2020 // read data words
whismanoid 0:3edb3708c8c5 2021 // @pre RAW_misoData16[index] contains the raw SPI Master-In,Slave-Out data
whismanoid 0:3edb3708c8c5 2022 // @pre AINcode[NUM_CHANNELS] contains the latest readings in LSBs
whismanoid 0:3edb3708c8c5 2023 // For internal clock modes, the data format always includes the channel address.
whismanoid 0:3edb3708c8c5 2024 // misoData16 = CH[3:0] DATA[11:0]
whismanoid 0:3edb3708c8c5 2025 void AINcode_print_value_chanID(CmdLine& cmdLine, int nWords)
whismanoid 0:3edb3708c8c5 2026 {
whismanoid 0:3edb3708c8c5 2027 cmdLine.serial().printf("ScanRead_nWords_chanID nWords=%d\r\n", nWords);
whismanoid 0:3edb3708c8c5 2028 for (int index = 0; index < nWords; index++) {
whismanoid 0:3edb3708c8c5 2029 //~ int16_t misoData16 = MAX11131_ScanRead();
whismanoid 0:3edb3708c8c5 2030 // For internal clock modes, the data format always includes the channel address.
whismanoid 0:3edb3708c8c5 2031 // misoData16 = CH[3:0] DATA[11:0]
whismanoid 0:3edb3708c8c5 2032 int16_t value_u12 = (g_MAX11131_device.RAW_misoData16[index] & 0x0FFF);
whismanoid 0:3edb3708c8c5 2033 int channelId = ((g_MAX11131_device.RAW_misoData16[index] >> 12) & 0x000F);
whismanoid 0:3edb3708c8c5 2034 // diagnostic: print raw MISO data
whismanoid 0:3edb3708c8c5 2035 cmdLine.serial().printf(" MAX11131.MISO[%u]=0x%4.4x:", index,
whismanoid 0:3edb3708c8c5 2036 (g_MAX11131_device.RAW_misoData16[index] & 0xFFFF));
whismanoid 0:3edb3708c8c5 2037 print_value(cmdLine, value_u12, channelId);
whismanoid 0:3edb3708c8c5 2038 cmdLine.serial().printf("\r\n");
whismanoid 0:3edb3708c8c5 2039 }
whismanoid 0:3edb3708c8c5 2040 }
whismanoid 0:3edb3708c8c5 2041
whismanoid 0:3edb3708c8c5 2042 //----------------------------------------
whismanoid 0:3edb3708c8c5 2043 // read data words
whismanoid 0:3edb3708c8c5 2044 // @pre RAW_misoData16[index] contains the raw SPI Master-In,Slave-Out data
whismanoid 0:3edb3708c8c5 2045 // @pre AINcode[NUM_CHANNELS] contains the latest readings in LSBs
whismanoid 0:3edb3708c8c5 2046 // For external clock modes, the data format returned depends on the CHAN_ID bit.
whismanoid 0:3edb3708c8c5 2047 // when CHAN_ID = 0: misoData16 = 0 DATA[11:0] x x x
whismanoid 0:3edb3708c8c5 2048 // when CHAN_ID = 1: misoData16 = CH[3:0] DATA[11:0]
whismanoid 0:3edb3708c8c5 2049 void AINcode_print_value_externalClock(CmdLine& cmdLine, int nWords)
whismanoid 0:3edb3708c8c5 2050 {
whismanoid 0:3edb3708c8c5 2051 // For external clock modes, the data format returned depends on the CHAN_ID bit.
whismanoid 0:3edb3708c8c5 2052 // when CHAN_ID = 0: misoData16 = 0 DATA[11:0] x x x
whismanoid 0:3edb3708c8c5 2053 // when CHAN_ID = 1: misoData16 = CH[3:0] DATA[11:0]
whismanoid 0:3edb3708c8c5 2054 // For internal clock modes, the data format always includes the channel address.
whismanoid 0:3edb3708c8c5 2055 // misoData16 = CH[3:0] DATA[11:0]
whismanoid 0:3edb3708c8c5 2056 if (g_MAX11131_device.chan_id_0_1 != 0) {
whismanoid 0:3edb3708c8c5 2057 AINcode_print_value_chanID(cmdLine, nWords);
whismanoid 0:3edb3708c8c5 2058 return;
whismanoid 0:3edb3708c8c5 2059 }
whismanoid 0:3edb3708c8c5 2060 cmdLine.serial().printf("ScanRead_nWords_externalClock nWords=%d\r\n", nWords);
whismanoid 0:3edb3708c8c5 2061 for (int index = 0; index < nWords; index++) {
whismanoid 0:3edb3708c8c5 2062 // int16_t misoData16 = MAX11131_ScanRead();
whismanoid 0:3edb3708c8c5 2063 int16_t value_u12 = ((g_MAX11131_device.RAW_misoData16[index] >> 3) & 0x0FFF);
whismanoid 0:3edb3708c8c5 2064 int channelId = g_MAX11131_device.channelNumber_0_15;
whismanoid 0:3edb3708c8c5 2065 // diagnostic: print raw MISO data
whismanoid 0:3edb3708c8c5 2066 cmdLine.serial().printf(" MAX11131.MISO[%u]=0x%4.4x:", index,
whismanoid 0:3edb3708c8c5 2067 (g_MAX11131_device.RAW_misoData16[index] & 0xFFFF));
whismanoid 0:3edb3708c8c5 2068 print_value(cmdLine, value_u12, channelId);
whismanoid 0:3edb3708c8c5 2069 cmdLine.serial().printf("\r\n");
whismanoid 0:3edb3708c8c5 2070 }
whismanoid 0:3edb3708c8c5 2071 }
whismanoid 0:3edb3708c8c5 2072
whismanoid 0:3edb3708c8c5 2073 //----------------------------------------
whismanoid 0:3edb3708c8c5 2074 // read data words and calculate mean, stddev
whismanoid 0:3edb3708c8c5 2075 // @pre RAW_misoData16[index] contains the raw SPI Master-In,Slave-Out data
whismanoid 0:3edb3708c8c5 2076 // @pre AINcode[NUM_CHANNELS] contains the latest readings in LSBs
whismanoid 0:3edb3708c8c5 2077 void AINcode_print_value_chanID_mean(CmdLine& cmdLine, int nWords)
whismanoid 0:3edb3708c8c5 2078 {
whismanoid 0:3edb3708c8c5 2079 cmdLine.serial().printf("ScanRead_nWords_chanID_mean nWords=%d\r\n", nWords);
whismanoid 0:3edb3708c8c5 2080 double Sx = 0;
whismanoid 0:3edb3708c8c5 2081 double Sxx = 0;
whismanoid 0:3edb3708c8c5 2082 for (int index = 0; index < nWords; index++) {
whismanoid 0:3edb3708c8c5 2083 //~ int16_t misoData16 = MAX11131_ScanRead();
whismanoid 0:3edb3708c8c5 2084 // For internal clock modes, the data format always includes the channel address.
whismanoid 0:3edb3708c8c5 2085 // misoData16 = CH[3:0] DATA[11:0]
whismanoid 0:3edb3708c8c5 2086 int16_t value_u12 = (g_MAX11131_device.RAW_misoData16[index] & 0x0FFF);
whismanoid 0:3edb3708c8c5 2087 int channelId = ((g_MAX11131_device.RAW_misoData16[index] >> 12) & 0x000F);
whismanoid 0:3edb3708c8c5 2088 // TODO: sign-extend value_s12 from value_u12
whismanoid 0:3edb3708c8c5 2089 //
whismanoid 0:3edb3708c8c5 2090 cmdLine.serial().printf("n=%d", index);
whismanoid 0:3edb3708c8c5 2091 print_value(cmdLine, value_u12, channelId);
whismanoid 0:3edb3708c8c5 2092 //
whismanoid 0:3edb3708c8c5 2093 Sx = Sx + value_u12;
whismanoid 0:3edb3708c8c5 2094 Sxx = Sxx + ((double)value_u12 * value_u12);
whismanoid 0:3edb3708c8c5 2095 cmdLine.serial().printf(" Sx=%f Sxx=%f\r\n", Sx, Sxx);
whismanoid 0:3edb3708c8c5 2096 }
whismanoid 0:3edb3708c8c5 2097 double mean = Sx / nWords;
whismanoid 0:3edb3708c8c5 2098 cmdLine.serial().printf(" mean=%f=0x%4.4x", mean, (int)mean);
whismanoid 0:3edb3708c8c5 2099 // calculate standard deviation from N, Sx, Sxx
whismanoid 0:3edb3708c8c5 2100 if (nWords >= 2)
whismanoid 0:3edb3708c8c5 2101 {
whismanoid 0:3edb3708c8c5 2102 double variance = (Sxx - ( Sx * Sx / nWords)) / (nWords - 1);
whismanoid 0:3edb3708c8c5 2103 // stddev = square root of variance
whismanoid 0:3edb3708c8c5 2104 double stddev = sqrt(variance);
whismanoid 0:3edb3708c8c5 2105 cmdLine.serial().printf(" variance=%f stddev=%f", variance, stddev);
whismanoid 0:3edb3708c8c5 2106 }
whismanoid 0:3edb3708c8c5 2107 cmdLine.serial().printf("\r\n");
whismanoid 0:3edb3708c8c5 2108 }
whismanoid 0:3edb3708c8c5 2109
whismanoid 0:3edb3708c8c5 2110 /* MAX11131_print_register_verbose
whismanoid 0:3edb3708c8c5 2111 *
whismanoid 0:3edb3708c8c5 2112 * TODO: document this function
whismanoid 0:3edb3708c8c5 2113 * This header was inserted by uncrustify; see uncrustify_func_header.txt.
whismanoid 0:3edb3708c8c5 2114 *
whismanoid 0:3edb3708c8c5 2115 */
whismanoid 0:3edb3708c8c5 2116 void MAX11131_print_register_verbose(CmdLine& cmdLine, int16_t registerData)
whismanoid 0:3edb3708c8c5 2117 {
whismanoid 0:3edb3708c8c5 2118 if (registerData & 0x8000)
whismanoid 0:3edb3708c8c5 2119 {
whismanoid 0:3edb3708c8c5 2120 switch (registerData & 0xF800)
whismanoid 0:3edb3708c8c5 2121 {
whismanoid 0:3edb3708c8c5 2122 case 0x8000: // ADC_CONFIGURATION 0x8000..0x87FF format: 1 0 0 0 0 REFSEL AVGON NAVG[1:0] NSCAN[1:0] SPM[1:0] ECHO 0 0
whismanoid 0:3edb3708c8c5 2123 cmdLine.serial().printf(" ADC_CONFIGURATION");
whismanoid 0:3edb3708c8c5 2124 {
whismanoid 0:3edb3708c8c5 2125 // define write-only register ADC_CONFIGURATION
whismanoid 0:3edb3708c8c5 2126 //int16_t ADC_CONFIGURATION = 0x8000; //!< registerData 0x8000..0x87FF format: 1 0 0 0 0 REFSEL AVGON NAVG[1:0] NSCAN[1:0] SPM[1:0] ECHO 0 0
whismanoid 0:3edb3708c8c5 2127 const int REFSEL_LSB = 10; const int REFSEL_BITS = 0x01; // ADC_CONFIGURATION.REFSEL
whismanoid 0:3edb3708c8c5 2128 const int AVGON_LSB = 9; const int AVGON_BITS = 0x01; // ADC_CONFIGURATION.AVGON
whismanoid 0:3edb3708c8c5 2129 const int NAVG_LSB = 7; const int NAVG_BITS = 0x03; // ADC_CONFIGURATION.NAVG[1:0]
whismanoid 0:3edb3708c8c5 2130 const int NSCAN_LSB = 5; const int NSCAN_BITS = 0x03; // ADC_CONFIGURATION.NSCAN[1:0]
whismanoid 0:3edb3708c8c5 2131 const int SPM_LSB = 3; const int SPM_BITS = 0x03; // ADC_CONFIGURATION.SPM[1:0]
whismanoid 0:3edb3708c8c5 2132 const int ECHO_LSB = 2; const int ECHO_BITS = 0x01; // ADC_CONFIGURATION.ECHO
whismanoid 0:3edb3708c8c5 2133
whismanoid 0:3edb3708c8c5 2134 const int REFSEL = ((registerData >> REFSEL_LSB) & REFSEL_BITS);
whismanoid 0:3edb3708c8c5 2135 const int AVGON = ((registerData >> AVGON_LSB) & AVGON_BITS);
whismanoid 0:3edb3708c8c5 2136 const int NAVG = ((registerData >> NAVG_LSB) & NAVG_BITS);
whismanoid 0:3edb3708c8c5 2137 const int NSCAN = ((registerData >> NSCAN_LSB) & NSCAN_BITS);
whismanoid 0:3edb3708c8c5 2138 const int SPM = ((registerData >> SPM_LSB) & SPM_BITS);
whismanoid 0:3edb3708c8c5 2139 const int ECHO = ((registerData >> ECHO_LSB) & ECHO_BITS);
whismanoid 0:3edb3708c8c5 2140
whismanoid 0:3edb3708c8c5 2141 if (REFSEL) {
whismanoid 0:3edb3708c8c5 2142 cmdLine.serial().printf(" REFSEL=%d", REFSEL);
whismanoid 0:3edb3708c8c5 2143 }
whismanoid 0:3edb3708c8c5 2144 if (AVGON) {
whismanoid 0:3edb3708c8c5 2145 cmdLine.serial().printf(" AVGON=%d", AVGON);
whismanoid 0:3edb3708c8c5 2146 }
whismanoid 0:3edb3708c8c5 2147 if (NAVG) {
whismanoid 0:3edb3708c8c5 2148 cmdLine.serial().printf(" NAVG=%d", NAVG);
whismanoid 0:3edb3708c8c5 2149 }
whismanoid 0:3edb3708c8c5 2150 if (NSCAN) {
whismanoid 0:3edb3708c8c5 2151 cmdLine.serial().printf(" NSCAN=%d", NSCAN);
whismanoid 0:3edb3708c8c5 2152 }
whismanoid 0:3edb3708c8c5 2153 if (SPM) {
whismanoid 0:3edb3708c8c5 2154 cmdLine.serial().printf(" SPM=%d", SPM);
whismanoid 0:3edb3708c8c5 2155 }
whismanoid 0:3edb3708c8c5 2156 if (ECHO) {
whismanoid 0:3edb3708c8c5 2157 cmdLine.serial().printf(" ECHO=%d", ECHO);
whismanoid 0:3edb3708c8c5 2158 }
whismanoid 0:3edb3708c8c5 2159 }
whismanoid 0:3edb3708c8c5 2160 break;
whismanoid 0:3edb3708c8c5 2161 case 0x8800: // UNIPOLAR 0x8800..0x8FFF format: 1 0 0 0 1 UCH0/1 UCH2/3 UCH4/5 UCH6/7 UCH8/9 UCH10/11 UCH12/13 UCH14/15 PDIFF_COM x x
whismanoid 0:3edb3708c8c5 2162 cmdLine.serial().printf(" UNIPOLAR 0x%4.4x", ((registerData >> 3) & 0xFF));
whismanoid 0:3edb3708c8c5 2163 if ((registerData >> 2) & 0x01) {
whismanoid 0:3edb3708c8c5 2164 cmdLine.serial().printf(" PDIFF_COM");
whismanoid 0:3edb3708c8c5 2165 }
whismanoid 0:3edb3708c8c5 2166 break;
whismanoid 0:3edb3708c8c5 2167 case 0x9000: // BIPOLAR 0x9000..0x97FF format: 1 0 0 1 0 BCH0/1 BCH2/3 BCH4/5 BCH6/7 BCH8/9 BCH10/11 BCH12/13 BCH14/15 x x x
whismanoid 0:3edb3708c8c5 2168 cmdLine.serial().printf(" BIPOLAR 0x%4.4x", ((registerData >> 3) & 0xFF));
whismanoid 0:3edb3708c8c5 2169 break;
whismanoid 0:3edb3708c8c5 2170 case 0x9800: // RANGE 0x9800..0x9FFF format: 1 0 0 1 1 RANGE0/1 RANGE2/3 RANGE4/5 RANGE6/7 RANGE8/9 RANGE10/11 RANGE12/13 RANGE14/15 x x x
whismanoid 0:3edb3708c8c5 2171 cmdLine.serial().printf(" RANGE 0x%4.4x", ((registerData >> 3) & 0xFF));
whismanoid 0:3edb3708c8c5 2172 break;
whismanoid 0:3edb3708c8c5 2173 case 0xA000: // CSCAN0 0xA000..0xA7FF format: 1 0 1 0 0 CHSCAN15 CHSCAN14 CHSCAN13 CHSCAN12 CHSCAN11 CHSCAN10 CHSCAN9 CHSCAN8 x x x
whismanoid 0:3edb3708c8c5 2174 cmdLine.serial().printf(" CSCAN0 0x%4.4x", ((registerData >> 3) & 0xFF));
whismanoid 0:3edb3708c8c5 2175 break;
whismanoid 0:3edb3708c8c5 2176 case 0xA800: // CSCAN1 0xA800..0xAFFF format: 1 0 1 0 1 CHSCAN7 CHSCAN6 CHSCAN5 CHSCAN4 CHSCAN3 CHSCAN2 CHSCAN1 CHSCAN0 x x x
whismanoid 0:3edb3708c8c5 2177 cmdLine.serial().printf(" CSCAN1 0x%4.4x", ((registerData >> 3) & 0xFF));
whismanoid 0:3edb3708c8c5 2178 break;
whismanoid 0:3edb3708c8c5 2179 case 0xB000: // SAMPLESET 0xB000..0xB7FF format: 1 0 1 1 0 SEQ_LENGTH[7:0] x x x
whismanoid 0:3edb3708c8c5 2180 cmdLine.serial().printf(" SAMPLESET SEQ_LENGTH[7:0]=0x%4.4x", ((registerData >> 3) & 0xFF));
whismanoid 0:3edb3708c8c5 2181 cmdLine.serial().printf(" so length=%d channels", (((registerData >> 3) & 0xFF) + 1));
whismanoid 0:3edb3708c8c5 2182 break;
whismanoid 0:3edb3708c8c5 2183 default:
whismanoid 0:3edb3708c8c5 2184 cmdLine.serial().printf(" ???");
whismanoid 0:3edb3708c8c5 2185 break;
whismanoid 0:3edb3708c8c5 2186 }
whismanoid 0:3edb3708c8c5 2187 }
whismanoid 0:3edb3708c8c5 2188 else
whismanoid 0:3edb3708c8c5 2189 {
whismanoid 0:3edb3708c8c5 2190 // ADC_MODE_CONTROL 0x0000..0x7FFF format: 0 SCAN[3:0] CHSEL[3:0] RESET[1:0] PM[1:0] CHAN_ID SWCNV 0
whismanoid 0:3edb3708c8c5 2191 cmdLine.serial().printf(" ADC_MODE_CONTROL");
whismanoid 0:3edb3708c8c5 2192
whismanoid 0:3edb3708c8c5 2193 // define write-only register ADC_MODE_CONTROL
whismanoid 0:3edb3708c8c5 2194 //int16_t ADC_MODE_CONTROL = 0; //!< registerData 0x0000..0x7FFF format: 0 SCAN[3:0] CHSEL[3:0] RESET[1:0] PM[1:0] CHAN_ID SWCNV 0
whismanoid 0:3edb3708c8c5 2195 const int SCAN_LSB = 11; const int SCAN_BITS = 0x0F; //!< ADC_MODE_CONTROL.SCAN[3:0] ADC Scan Control (command)
whismanoid 0:3edb3708c8c5 2196 const int CHSEL_LSB = 7; const int CHSEL_BITS = 0x0F; //!< ADC_MODE_CONTROL.CHSEL[3:0] Analog Input Channel Select AIN0..AIN15
whismanoid 0:3edb3708c8c5 2197 const int RESET_LSB = 5; const int RESET_BITS = 0x03; //!< ADC_MODE_CONTROL.RESET[1:0] Reset 0=Normal 1=ResetFIFO 2=ResetAllRegisters 3=reserved
whismanoid 0:3edb3708c8c5 2198 const int PM_LSB = 3; const int PM_BITS = 0x03; //!< ADC_MODE_CONTROL.PM[1:0] Power Management 0=Normal, 1=AutoShutdown, 2=AutoStandby 3=reserved
whismanoid 0:3edb3708c8c5 2199 const int CHAN_ID_LSB = 2; const int CHAN_ID_BITS = 0x01; //!< ADC_MODE_CONTROL.CHAN_ID
whismanoid 0:3edb3708c8c5 2200 const int SWCNV_LSB = 1; const int SWCNV_BITS = 0x01; //!< ADC_MODE_CONTROL.SWCNV
whismanoid 0:3edb3708c8c5 2201
whismanoid 0:3edb3708c8c5 2202 const int SCAN = ((registerData >> SCAN_LSB) & SCAN_BITS);
whismanoid 0:3edb3708c8c5 2203 const int CHSEL = ((registerData >> CHSEL_LSB) & CHSEL_BITS);
whismanoid 0:3edb3708c8c5 2204 const int RESET = ((registerData >> RESET_LSB) & RESET_BITS);
whismanoid 0:3edb3708c8c5 2205 const int PM = ((registerData >> PM_LSB) & PM_BITS);
whismanoid 0:3edb3708c8c5 2206 const int CHANID = ((registerData >> CHAN_ID_LSB) & CHAN_ID_BITS);
whismanoid 0:3edb3708c8c5 2207 const int SWCNV = ((registerData >> SWCNV_LSB) & SWCNV_BITS);
whismanoid 0:3edb3708c8c5 2208
whismanoid 0:3edb3708c8c5 2209 switch (SCAN)
whismanoid 0:3edb3708c8c5 2210 {
whismanoid 0:3edb3708c8c5 2211 case MAX11131::SCAN_0000_NOP:
whismanoid 0:3edb3708c8c5 2212 cmdLine.serial().printf(" SCAN_0000_NOP");
whismanoid 0:3edb3708c8c5 2213 break;
whismanoid 0:3edb3708c8c5 2214 case MAX11131::SCAN_0001_Manual:
whismanoid 0:3edb3708c8c5 2215 cmdLine.serial().printf(" SCAN_0001_Manual CHSEL=%d", CHSEL);
whismanoid 0:3edb3708c8c5 2216 break;
whismanoid 0:3edb3708c8c5 2217 case MAX11131::SCAN_0010_Repeat:
whismanoid 0:3edb3708c8c5 2218 cmdLine.serial().printf(" SCAN_0010_Repeat CHSEL=%d", CHSEL);
whismanoid 0:3edb3708c8c5 2219 break;
whismanoid 0:3edb3708c8c5 2220 case MAX11131::SCAN_0011_StandardInternalClock:
whismanoid 0:3edb3708c8c5 2221 cmdLine.serial().printf(" SCAN_0011_StandardInt CHSEL=%d", CHSEL);
whismanoid 0:3edb3708c8c5 2222 break;
whismanoid 0:3edb3708c8c5 2223 case MAX11131::SCAN_0100_StandardExternalClock:
whismanoid 0:3edb3708c8c5 2224 cmdLine.serial().printf(" SCAN_0100_StandardExt CHSEL=%d", CHSEL);
whismanoid 0:3edb3708c8c5 2225 break;
whismanoid 0:3edb3708c8c5 2226 case MAX11131::SCAN_0101_UpperInternalClock:
whismanoid 0:3edb3708c8c5 2227 cmdLine.serial().printf(" SCAN_0101_UpperInt CHSEL=%d", CHSEL);
whismanoid 0:3edb3708c8c5 2228 break;
whismanoid 0:3edb3708c8c5 2229 case MAX11131::SCAN_0110_UpperExternalClock:
whismanoid 0:3edb3708c8c5 2230 cmdLine.serial().printf(" SCAN_0110_UpperExt CHSEL=%d", CHSEL);
whismanoid 0:3edb3708c8c5 2231 break;
whismanoid 0:3edb3708c8c5 2232 case MAX11131::SCAN_0111_CustomInternalClock:
whismanoid 0:3edb3708c8c5 2233 cmdLine.serial().printf(" SCAN_0111_CustomInt");
whismanoid 0:3edb3708c8c5 2234 break;
whismanoid 0:3edb3708c8c5 2235 case MAX11131::SCAN_1000_CustomExternalClock:
whismanoid 0:3edb3708c8c5 2236 cmdLine.serial().printf(" SCAN_1000_CustomExt");
whismanoid 0:3edb3708c8c5 2237 break;
whismanoid 0:3edb3708c8c5 2238 case MAX11131::SCAN_1001_SampleSetExternalClock:
whismanoid 0:3edb3708c8c5 2239 cmdLine.serial().printf(" SCAN_1001_SampleSetExt");
whismanoid 0:3edb3708c8c5 2240 break;
whismanoid 0:3edb3708c8c5 2241 default:
whismanoid 0:3edb3708c8c5 2242 cmdLine.serial().printf(" SCAN=%d", SCAN);
whismanoid 0:3edb3708c8c5 2243 cmdLine.serial().printf(" CHSEL=%d", CHSEL);
whismanoid 0:3edb3708c8c5 2244 }
whismanoid 0:3edb3708c8c5 2245 if (RESET) {
whismanoid 0:3edb3708c8c5 2246 cmdLine.serial().printf(" RESET=%d", RESET);
whismanoid 0:3edb3708c8c5 2247 }
whismanoid 0:3edb3708c8c5 2248 if (PM) {
whismanoid 0:3edb3708c8c5 2249 cmdLine.serial().printf(" PM=%d", PM);
whismanoid 0:3edb3708c8c5 2250 }
whismanoid 0:3edb3708c8c5 2251 if (SCAN != MAX11131::SCAN_0000_NOP)
whismanoid 0:3edb3708c8c5 2252 {
whismanoid 0:3edb3708c8c5 2253 if (g_MAX11131_device.isExternalClock)
whismanoid 0:3edb3708c8c5 2254 {
whismanoid 0:3edb3708c8c5 2255 // if external clock mode, print CHANID
whismanoid 0:3edb3708c8c5 2256 cmdLine.serial().printf(" CHANID=%d", CHANID);
whismanoid 0:3edb3708c8c5 2257 }
whismanoid 0:3edb3708c8c5 2258 else
whismanoid 0:3edb3708c8c5 2259 {
whismanoid 0:3edb3708c8c5 2260 // if internal clock mode, print SWCNV
whismanoid 0:3edb3708c8c5 2261 cmdLine.serial().printf(" SWCNV=%d", SWCNV);
whismanoid 0:3edb3708c8c5 2262 }
whismanoid 0:3edb3708c8c5 2263 }
whismanoid 0:3edb3708c8c5 2264 }
whismanoid 0:3edb3708c8c5 2265 cmdLine.serial().printf("\r\n");
whismanoid 0:3edb3708c8c5 2266 }
whismanoid 0:3edb3708c8c5 2267
whismanoid 0:3edb3708c8c5 2268 //----------------------------------------
whismanoid 0:3edb3708c8c5 2269 // User-provided hardware function
whismanoid 0:3edb3708c8c5 2270 // declare user-provided hardware interface function
whismanoid 0:3edb3708c8c5 2271 // Assert CNVST convert start.
whismanoid 0:3edb3708c8c5 2272 // Required when using any of the InternalClock modes with SWCNV 0.
whismanoid 0:3edb3708c8c5 2273 // Trigger measurement by driving CNVST/AIN14 pin low for a minimum active-low pulse duration of 5ns. (AIN14 is not available)
whismanoid 0:3edb3708c8c5 2274 //
whismanoid 0:3edb3708c8c5 2275 //void CNVSToutputPulseLow()
whismanoid 0:3edb3708c8c5 2276 //{
whismanoid 0:3edb3708c8c5 2277 // digitalInOut9.output();
whismanoid 0:3edb3708c8c5 2278 // digitalInOut9.write(0);
whismanoid 0:3edb3708c8c5 2279 // // CNVST active-low pulse duration must be 5ns (0.005us) minimum.
whismanoid 0:3edb3708c8c5 2280 // digitalInOut9.write(1);
whismanoid 0:3edb3708c8c5 2281 //
whismanoid 0:3edb3708c8c5 2282 //#if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 2283 // cmdLine_microUSBserial.serial().printf(" CNVSToutputPulseLow ");
whismanoid 0:3edb3708c8c5 2284 //#endif
whismanoid 0:3edb3708c8c5 2285 //#if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 2286 // cmdLine_DAPLINKserial.serial().printf(" CNVSToutputPulseLow ");
whismanoid 0:3edb3708c8c5 2287 //#endif
whismanoid 0:3edb3708c8c5 2288 //}
whismanoid 0:3edb3708c8c5 2289
whismanoid 0:3edb3708c8c5 2290 //----------------------------------------
whismanoid 0:3edb3708c8c5 2291 // User-provided hardware function
whismanoid 0:3edb3708c8c5 2292 // declare user-provided hardware interface function
whismanoid 0:3edb3708c8c5 2293 // Wait for EOC pin low, indicating end of conversion.
whismanoid 0:3edb3708c8c5 2294 // Required when using any of the InternalClock modes.
whismanoid 0:3edb3708c8c5 2295 //
whismanoid 0:3edb3708c8c5 2296 //void EOCinputWaitUntilLow()
whismanoid 0:3edb3708c8c5 2297 //{
whismanoid 0:3edb3708c8c5 2298 // //
whismanoid 0:3edb3708c8c5 2299 // // Arduino: pulseIn(pinIndex, HIGH | LOW, timeout_usec) // length of pulse in usec, or 0 if timeout
whismanoid 0:3edb3708c8c5 2300 // //
whismanoid 0:3edb3708c8c5 2301 // // const int timeout_usec = 1000;
whismanoid 0:3edb3708c8c5 2302 // // TODO1: implement EOCinputWaitUntilLow APPLICATION_MAX11131
whismanoid 0:3edb3708c8c5 2303 // // similar to Arduino pulseIn(MAX11131_EOC_Pin, LOW, timeout_usec);
whismanoid 0:3edb3708c8c5 2304 //#if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 2305 // cmdLine_microUSBserial.serial().printf(" EOCinputWaitUntilLow ");
whismanoid 0:3edb3708c8c5 2306 //#endif
whismanoid 0:3edb3708c8c5 2307 //#if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 2308 // cmdLine_DAPLINKserial.serial().printf(" EOCinputWaitUntilLow ");
whismanoid 0:3edb3708c8c5 2309 //#endif
whismanoid 0:3edb3708c8c5 2310 //}
whismanoid 0:3edb3708c8c5 2311
whismanoid 0:3edb3708c8c5 2312 //----------------------------------------
whismanoid 0:3edb3708c8c5 2313 // User-provided hardware function
whismanoid 0:3edb3708c8c5 2314 // declare user-provided hardware interface function
whismanoid 0:3edb3708c8c5 2315 // Assert SPI Chip Select
whismanoid 0:3edb3708c8c5 2316 // SPI chip-select for MAX5715
whismanoid 0:3edb3708c8c5 2317 //
whismanoid 0:3edb3708c8c5 2318 //void SPIoutputCS(int isLogicHigh)
whismanoid 0:3edb3708c8c5 2319 //{
whismanoid 0:3edb3708c8c5 2320 // g_SPI_cs_state = isLogicHigh;
whismanoid 0:3edb3708c8c5 2321 // spi_cs = g_SPI_cs_state;
whismanoid 0:3edb3708c8c5 2322 //}
whismanoid 0:3edb3708c8c5 2323
whismanoid 0:3edb3708c8c5 2324 //----------------------------------------
whismanoid 0:3edb3708c8c5 2325 // User-provided hardware function
whismanoid 0:3edb3708c8c5 2326 // declare user-provided hardware interface function SPI write 16 bits
whismanoid 0:3edb3708c8c5 2327 // SPI interface to MAX11131 shift 16 bits mosiData16 into MAX11131 DIN
whismanoid 0:3edb3708c8c5 2328 // ignoring MAX11131 DOUT
whismanoid 0:3edb3708c8c5 2329 //void SPIwrite16bits(int16_t mosiData16)
whismanoid 0:3edb3708c8c5 2330 //{
whismanoid 0:3edb3708c8c5 2331 // // TODO1: implement SPIwrite16bits
whismanoid 0:3edb3708c8c5 2332 // size_t byteCount = 2;
whismanoid 0:3edb3708c8c5 2333 // static char mosiData[2];
whismanoid 0:3edb3708c8c5 2334 // static char misoData[2];
whismanoid 0:3edb3708c8c5 2335 // mosiData[0] = (char)((mosiData16 >> 8) & 0xFF); // MSByte
whismanoid 0:3edb3708c8c5 2336 // mosiData[1] = (char)((mosiData16 >> 0) & 0xFF); // LSByte
whismanoid 0:3edb3708c8c5 2337 // //
whismanoid 0:3edb3708c8c5 2338 // // Arduino: begin critical section: noInterrupts() masks all interrupt sources; end critical section with interrupts()
whismanoid 0:3edb3708c8c5 2339 // //~ noInterrupts();
whismanoid 0:3edb3708c8c5 2340 // //
whismanoid 0:3edb3708c8c5 2341 // //~ digitalWrite(Scope_Trigger_Pin, LOW); // diagnostic Scope_Trigger_Pin
whismanoid 0:3edb3708c8c5 2342 // //
whismanoid 0:3edb3708c8c5 2343 // unsigned int numBytesTransferred = spi.write(mosiData, byteCount, misoData, byteCount);
whismanoid 0:3edb3708c8c5 2344 // //~ SPI.transfer(mosiData8_FF0000);
whismanoid 0:3edb3708c8c5 2345 // //~ SPI.transfer(mosiData16_00FF00);
whismanoid 0:3edb3708c8c5 2346 // //~ SPI.transfer(mosiData16_0000FF);
whismanoid 0:3edb3708c8c5 2347 // //
whismanoid 0:3edb3708c8c5 2348 // //~ digitalWrite(Scope_Trigger_Pin, HIGH); // diagnostic Scope_Trigger_Pin
whismanoid 0:3edb3708c8c5 2349 // //
whismanoid 0:3edb3708c8c5 2350 // // Arduino: begin critical section: noInterrupts() masks all interrupt sources; end critical section with interrupts()
whismanoid 0:3edb3708c8c5 2351 // //~ interrupts();
whismanoid 0:3edb3708c8c5 2352 // //
whismanoid 0:3edb3708c8c5 2353 // // VERIFY: SPIwrite24bits print diagnostic information
whismanoid 0:3edb3708c8c5 2354 // //cmdLine.serial().printf(" MOSI->"));
whismanoid 0:3edb3708c8c5 2355 // //cmdLine.serial().printf(" 0x"));
whismanoid 0:3edb3708c8c5 2356 // //Serial.print( (mosiData8_FF0000 & 0xFF), HEX);
whismanoid 0:3edb3708c8c5 2357 // //cmdLine.serial().printf(" 0x"));
whismanoid 0:3edb3708c8c5 2358 // //Serial.print( (mosiData16_00FF00 & 0xFF), HEX);
whismanoid 0:3edb3708c8c5 2359 // //cmdLine.serial().printf(" 0x"));
whismanoid 0:3edb3708c8c5 2360 // //Serial.print( (mosiData16_0000FF & 0xFF), HEX);
whismanoid 0:3edb3708c8c5 2361 // // hex dump mosiData[0..byteCount-1]
whismanoid 0:3edb3708c8c5 2362 //#if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 2363 // cmdLine_microUSBserial.serial().printf("\r\nSPI");
whismanoid 0:3edb3708c8c5 2364 // if (byteCount > 7) {
whismanoid 0:3edb3708c8c5 2365 // cmdLine_microUSBserial.serial().printf(" byteCount:%d", byteCount);
whismanoid 0:3edb3708c8c5 2366 // }
whismanoid 0:3edb3708c8c5 2367 // cmdLine_microUSBserial.serial().printf(" MOSI->");
whismanoid 0:3edb3708c8c5 2368 // for (unsigned int byteIndex = 0; byteIndex < byteCount; byteIndex++)
whismanoid 0:3edb3708c8c5 2369 // {
whismanoid 0:3edb3708c8c5 2370 // cmdLine_microUSBserial.serial().printf(" 0x%2.2X", mosiData[byteIndex]);
whismanoid 0:3edb3708c8c5 2371 // }
whismanoid 0:3edb3708c8c5 2372 // // hex dump misoData[0..byteCount-1]
whismanoid 0:3edb3708c8c5 2373 // cmdLine_microUSBserial.serial().printf(" MISO<-");
whismanoid 0:3edb3708c8c5 2374 // for (unsigned int byteIndex = 0; byteIndex < numBytesTransferred; byteIndex++)
whismanoid 0:3edb3708c8c5 2375 // {
whismanoid 0:3edb3708c8c5 2376 // cmdLine_microUSBserial.serial().printf(" 0x%2.2X", misoData[byteIndex]);
whismanoid 0:3edb3708c8c5 2377 // }
whismanoid 0:3edb3708c8c5 2378 // cmdLine_microUSBserial.serial().printf(" ");
whismanoid 0:3edb3708c8c5 2379 //#endif
whismanoid 0:3edb3708c8c5 2380 //#if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 2381 // cmdLine_DAPLINKserial.serial().printf("\r\nSPI");
whismanoid 0:3edb3708c8c5 2382 // if (byteCount > 7) {
whismanoid 0:3edb3708c8c5 2383 // cmdLine_DAPLINKserial.serial().printf(" byteCount:%d", byteCount);
whismanoid 0:3edb3708c8c5 2384 // }
whismanoid 0:3edb3708c8c5 2385 // cmdLine_DAPLINKserial.serial().printf(" MOSI->");
whismanoid 0:3edb3708c8c5 2386 // for (unsigned int byteIndex = 0; byteIndex < byteCount; byteIndex++)
whismanoid 0:3edb3708c8c5 2387 // {
whismanoid 0:3edb3708c8c5 2388 // cmdLine_DAPLINKserial.serial().printf(" 0x%2.2X", mosiData[byteIndex]);
whismanoid 0:3edb3708c8c5 2389 // }
whismanoid 0:3edb3708c8c5 2390 // // hex dump misoData[0..byteCount-1]
whismanoid 0:3edb3708c8c5 2391 // cmdLine_DAPLINKserial.serial().printf(" MISO<-");
whismanoid 0:3edb3708c8c5 2392 // for (unsigned int byteIndex = 0; byteIndex < numBytesTransferred; byteIndex++)
whismanoid 0:3edb3708c8c5 2393 // {
whismanoid 0:3edb3708c8c5 2394 // cmdLine_DAPLINKserial.serial().printf(" 0x%2.2X", misoData[byteIndex]);
whismanoid 0:3edb3708c8c5 2395 // }
whismanoid 0:3edb3708c8c5 2396 // cmdLine_DAPLINKserial.serial().printf(" ");
whismanoid 0:3edb3708c8c5 2397 //#endif
whismanoid 0:3edb3708c8c5 2398 // // VERIFY: DIAGNOSTIC: print MAX5715 device register write
whismanoid 0:3edb3708c8c5 2399 // // TODO: MAX5715_print_register_verbose(mosiData8_FF0000, mosiData16_00FFFF);
whismanoid 0:3edb3708c8c5 2400 // // TODO: print_verbose_SPI_diagnostic(mosiData16_FF00, mosiData16_00FF, misoData16_FF00, misoData16_00FF);
whismanoid 0:3edb3708c8c5 2401 // //
whismanoid 0:3edb3708c8c5 2402 // // int misoData16 = (misoData16_FF00 << 8) | misoData16_00FF;
whismanoid 0:3edb3708c8c5 2403 // // return misoData16;
whismanoid 0:3edb3708c8c5 2404 //}
whismanoid 0:3edb3708c8c5 2405
whismanoid 0:3edb3708c8c5 2406 //----------------------------------------
whismanoid 0:3edb3708c8c5 2407 // User-provided hardware function
whismanoid 0:3edb3708c8c5 2408 // declare user-provided hardware interface function SPI write 17-24 bits
whismanoid 0:3edb3708c8c5 2409 // SPI interface to MAX11131 shift 16 bits mosiData16 into MAX11131 DIN
whismanoid 0:3edb3708c8c5 2410 // followed by one additional SCLK byte.
whismanoid 0:3edb3708c8c5 2411 // ignoring MAX11131 DOUT
whismanoid 0:3edb3708c8c5 2412 //void SPIwrite24bits(int16_t mosiData16_FFFF00, int8_t mosiData8_0000FF)
whismanoid 0:3edb3708c8c5 2413 //{
whismanoid 0:3edb3708c8c5 2414 // // TODO1: implement SPIwrite24bits
whismanoid 0:3edb3708c8c5 2415 // size_t byteCount = 3;
whismanoid 0:3edb3708c8c5 2416 // static char mosiData[3];
whismanoid 0:3edb3708c8c5 2417 // static char misoData[3];
whismanoid 0:3edb3708c8c5 2418 // mosiData[0] = (char)((mosiData16_FFFF00 >> 8) & 0xFF); // MSByte
whismanoid 0:3edb3708c8c5 2419 // mosiData[1] = (char)((mosiData16_FFFF00 >> 0) & 0xFF); // LSByte
whismanoid 0:3edb3708c8c5 2420 // mosiData[2] = mosiData8_0000FF;
whismanoid 0:3edb3708c8c5 2421 // //
whismanoid 0:3edb3708c8c5 2422 // // Arduino: begin critical section: noInterrupts() masks all interrupt sources; end critical section with interrupts()
whismanoid 0:3edb3708c8c5 2423 // //~ noInterrupts();
whismanoid 0:3edb3708c8c5 2424 // //
whismanoid 0:3edb3708c8c5 2425 // //~ digitalWrite(Scope_Trigger_Pin, LOW); // diagnostic Scope_Trigger_Pin
whismanoid 0:3edb3708c8c5 2426 // //
whismanoid 0:3edb3708c8c5 2427 // unsigned int numBytesTransferred = spi.write(mosiData, byteCount, misoData, byteCount);
whismanoid 0:3edb3708c8c5 2428 // //~ SPI.transfer(mosiData8_FF0000);
whismanoid 0:3edb3708c8c5 2429 // //~ SPI.transfer(mosiData16_00FF00);
whismanoid 0:3edb3708c8c5 2430 // //~ SPI.transfer(mosiData16_0000FF);
whismanoid 0:3edb3708c8c5 2431 // //
whismanoid 0:3edb3708c8c5 2432 // //~ digitalWrite(Scope_Trigger_Pin, HIGH); // diagnostic Scope_Trigger_Pin
whismanoid 0:3edb3708c8c5 2433 // //
whismanoid 0:3edb3708c8c5 2434 // // Arduino: begin critical section: noInterrupts() masks all interrupt sources; end critical section with interrupts()
whismanoid 0:3edb3708c8c5 2435 // //~ interrupts();
whismanoid 0:3edb3708c8c5 2436 // //
whismanoid 0:3edb3708c8c5 2437 // // VERIFY: SPIwrite24bits print diagnostic information
whismanoid 0:3edb3708c8c5 2438 // //cmdLine.serial().printf(" MOSI->"));
whismanoid 0:3edb3708c8c5 2439 // //cmdLine.serial().printf(" 0x"));
whismanoid 0:3edb3708c8c5 2440 // //Serial.print( (mosiData8_FF0000 & 0xFF), HEX);
whismanoid 0:3edb3708c8c5 2441 // //cmdLine.serial().printf(" 0x"));
whismanoid 0:3edb3708c8c5 2442 // //Serial.print( (mosiData16_00FF00 & 0xFF), HEX);
whismanoid 0:3edb3708c8c5 2443 // //cmdLine.serial().printf(" 0x"));
whismanoid 0:3edb3708c8c5 2444 // //Serial.print( (mosiData16_0000FF & 0xFF), HEX);
whismanoid 0:3edb3708c8c5 2445 // // hex dump mosiData[0..byteCount-1]
whismanoid 0:3edb3708c8c5 2446 //#if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 2447 // cmdLine_microUSBserial.serial().printf("\r\nSPI");
whismanoid 0:3edb3708c8c5 2448 // if (byteCount > 7) {
whismanoid 0:3edb3708c8c5 2449 // cmdLine_microUSBserial.serial().printf(" byteCount:%d", byteCount);
whismanoid 0:3edb3708c8c5 2450 // }
whismanoid 0:3edb3708c8c5 2451 // cmdLine_microUSBserial.serial().printf(" MOSI->");
whismanoid 0:3edb3708c8c5 2452 // for (unsigned int byteIndex = 0; byteIndex < byteCount; byteIndex++)
whismanoid 0:3edb3708c8c5 2453 // {
whismanoid 0:3edb3708c8c5 2454 // cmdLine_microUSBserial.serial().printf(" 0x%2.2X", mosiData[byteIndex]);
whismanoid 0:3edb3708c8c5 2455 // }
whismanoid 0:3edb3708c8c5 2456 // // hex dump misoData[0..byteCount-1]
whismanoid 0:3edb3708c8c5 2457 // cmdLine_microUSBserial.serial().printf(" MISO<-");
whismanoid 0:3edb3708c8c5 2458 // for (unsigned int byteIndex = 0; byteIndex < numBytesTransferred; byteIndex++)
whismanoid 0:3edb3708c8c5 2459 // {
whismanoid 0:3edb3708c8c5 2460 // cmdLine_microUSBserial.serial().printf(" 0x%2.2X", misoData[byteIndex]);
whismanoid 0:3edb3708c8c5 2461 // }
whismanoid 0:3edb3708c8c5 2462 // cmdLine_microUSBserial.serial().printf(" ");
whismanoid 0:3edb3708c8c5 2463 //#endif
whismanoid 0:3edb3708c8c5 2464 //#if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 2465 // cmdLine_DAPLINKserial.serial().printf("\r\nSPI");
whismanoid 0:3edb3708c8c5 2466 // if (byteCount > 7) {
whismanoid 0:3edb3708c8c5 2467 // cmdLine_DAPLINKserial.serial().printf(" byteCount:%d", byteCount);
whismanoid 0:3edb3708c8c5 2468 // }
whismanoid 0:3edb3708c8c5 2469 // cmdLine_DAPLINKserial.serial().printf(" MOSI->");
whismanoid 0:3edb3708c8c5 2470 // for (unsigned int byteIndex = 0; byteIndex < byteCount; byteIndex++)
whismanoid 0:3edb3708c8c5 2471 // {
whismanoid 0:3edb3708c8c5 2472 // cmdLine_DAPLINKserial.serial().printf(" 0x%2.2X", mosiData[byteIndex]);
whismanoid 0:3edb3708c8c5 2473 // }
whismanoid 0:3edb3708c8c5 2474 // // hex dump misoData[0..byteCount-1]
whismanoid 0:3edb3708c8c5 2475 // cmdLine_DAPLINKserial.serial().printf(" MISO<-");
whismanoid 0:3edb3708c8c5 2476 // for (unsigned int byteIndex = 0; byteIndex < numBytesTransferred; byteIndex++)
whismanoid 0:3edb3708c8c5 2477 // {
whismanoid 0:3edb3708c8c5 2478 // cmdLine_DAPLINKserial.serial().printf(" 0x%2.2X", misoData[byteIndex]);
whismanoid 0:3edb3708c8c5 2479 // }
whismanoid 0:3edb3708c8c5 2480 // cmdLine_DAPLINKserial.serial().printf(" ");
whismanoid 0:3edb3708c8c5 2481 //#endif
whismanoid 0:3edb3708c8c5 2482 // // VERIFY: DIAGNOSTIC: print MAX5715 device register write
whismanoid 0:3edb3708c8c5 2483 // // TODO: MAX5715_print_register_verbose(mosiData8_FF0000, mosiData16_00FFFF);
whismanoid 0:3edb3708c8c5 2484 // //
whismanoid 0:3edb3708c8c5 2485 // // int misoData16 = (misoData16_FF00 << 8) | misoData16_00FF;
whismanoid 0:3edb3708c8c5 2486 // // return misoData16;
whismanoid 0:3edb3708c8c5 2487 //}
whismanoid 0:3edb3708c8c5 2488
whismanoid 0:3edb3708c8c5 2489 //----------------------------------------
whismanoid 0:3edb3708c8c5 2490 // User-provided hardware function
whismanoid 0:3edb3708c8c5 2491 // declare user-provided hardware interface function SPI read 16 bits while MOSI (Maxim DIN) is 0
whismanoid 0:3edb3708c8c5 2492 // SPI interface to capture 16 bits miso data from MAX11131 DOUT
whismanoid 0:3edb3708c8c5 2493 //int16_t SPIread16bits()
whismanoid 0:3edb3708c8c5 2494 //{
whismanoid 0:3edb3708c8c5 2495 // // TODO1: implement SPIread16bits
whismanoid 0:3edb3708c8c5 2496 // int mosiData16 = 0;
whismanoid 0:3edb3708c8c5 2497 // size_t byteCount = 2;
whismanoid 0:3edb3708c8c5 2498 // static char mosiData[2];
whismanoid 0:3edb3708c8c5 2499 // static char misoData[2];
whismanoid 0:3edb3708c8c5 2500 // mosiData[0] = (char)((mosiData16 >> 8) & 0xFF); // MSByte
whismanoid 0:3edb3708c8c5 2501 // mosiData[1] = (char)((mosiData16 >> 0) & 0xFF); // LSByte
whismanoid 0:3edb3708c8c5 2502 // //
whismanoid 0:3edb3708c8c5 2503 // // Arduino: begin critical section: noInterrupts() masks all interrupt sources; end critical section with interrupts()
whismanoid 0:3edb3708c8c5 2504 // //~ noInterrupts();
whismanoid 0:3edb3708c8c5 2505 // //
whismanoid 0:3edb3708c8c5 2506 // //~ digitalWrite(Scope_Trigger_Pin, LOW); // diagnostic Scope_Trigger_Pin
whismanoid 0:3edb3708c8c5 2507 // //
whismanoid 0:3edb3708c8c5 2508 // unsigned int numBytesTransferred = spi.write(mosiData, byteCount, misoData, byteCount);
whismanoid 0:3edb3708c8c5 2509 // //~ SPI.transfer(mosiData8_FF0000);
whismanoid 0:3edb3708c8c5 2510 // //~ SPI.transfer(mosiData16_00FF00);
whismanoid 0:3edb3708c8c5 2511 // //~ SPI.transfer(mosiData16_0000FF);
whismanoid 0:3edb3708c8c5 2512 // //
whismanoid 0:3edb3708c8c5 2513 // //~ digitalWrite(Scope_Trigger_Pin, HIGH); // diagnostic Scope_Trigger_Pin
whismanoid 0:3edb3708c8c5 2514 // //
whismanoid 0:3edb3708c8c5 2515 // // Arduino: begin critical section: noInterrupts() masks all interrupt sources; end critical section with interrupts()
whismanoid 0:3edb3708c8c5 2516 // //~ interrupts();
whismanoid 0:3edb3708c8c5 2517 // //
whismanoid 0:3edb3708c8c5 2518 // // VERIFY: SPIwrite24bits print diagnostic information
whismanoid 0:3edb3708c8c5 2519 // //cmdLine.serial().printf(" MOSI->"));
whismanoid 0:3edb3708c8c5 2520 // //cmdLine.serial().printf(" 0x"));
whismanoid 0:3edb3708c8c5 2521 // //Serial.print( (mosiData8_FF0000 & 0xFF), HEX);
whismanoid 0:3edb3708c8c5 2522 // //cmdLine.serial().printf(" 0x"));
whismanoid 0:3edb3708c8c5 2523 // //Serial.print( (mosiData16_00FF00 & 0xFF), HEX);
whismanoid 0:3edb3708c8c5 2524 // //cmdLine.serial().printf(" 0x"));
whismanoid 0:3edb3708c8c5 2525 // //Serial.print( (mosiData16_0000FF & 0xFF), HEX);
whismanoid 0:3edb3708c8c5 2526 // // hex dump mosiData[0..byteCount-1]
whismanoid 0:3edb3708c8c5 2527 //#if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 2528 // cmdLine_microUSBserial.serial().printf("\r\nSPI");
whismanoid 0:3edb3708c8c5 2529 // if (byteCount > 7) {
whismanoid 0:3edb3708c8c5 2530 // cmdLine_microUSBserial.serial().printf(" byteCount:%d", byteCount);
whismanoid 0:3edb3708c8c5 2531 // }
whismanoid 0:3edb3708c8c5 2532 // cmdLine_microUSBserial.serial().printf(" MOSI->");
whismanoid 0:3edb3708c8c5 2533 // for (unsigned int byteIndex = 0; byteIndex < byteCount; byteIndex++)
whismanoid 0:3edb3708c8c5 2534 // {
whismanoid 0:3edb3708c8c5 2535 // cmdLine_microUSBserial.serial().printf(" 0x%2.2X", mosiData[byteIndex]);
whismanoid 0:3edb3708c8c5 2536 // }
whismanoid 0:3edb3708c8c5 2537 // // hex dump misoData[0..byteCount-1]
whismanoid 0:3edb3708c8c5 2538 // cmdLine_microUSBserial.serial().printf(" MISO<-");
whismanoid 0:3edb3708c8c5 2539 // for (unsigned int byteIndex = 0; byteIndex < numBytesTransferred; byteIndex++)
whismanoid 0:3edb3708c8c5 2540 // {
whismanoid 0:3edb3708c8c5 2541 // cmdLine_microUSBserial.serial().printf(" 0x%2.2X", misoData[byteIndex]);
whismanoid 0:3edb3708c8c5 2542 // }
whismanoid 0:3edb3708c8c5 2543 // cmdLine_microUSBserial.serial().printf(" ");
whismanoid 0:3edb3708c8c5 2544 //#endif
whismanoid 0:3edb3708c8c5 2545 //#if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 2546 // cmdLine_DAPLINKserial.serial().printf("\r\nSPI");
whismanoid 0:3edb3708c8c5 2547 // if (byteCount > 7) {
whismanoid 0:3edb3708c8c5 2548 // cmdLine_DAPLINKserial.serial().printf(" byteCount:%d", byteCount);
whismanoid 0:3edb3708c8c5 2549 // }
whismanoid 0:3edb3708c8c5 2550 // cmdLine_DAPLINKserial.serial().printf(" MOSI->");
whismanoid 0:3edb3708c8c5 2551 // for (unsigned int byteIndex = 0; byteIndex < byteCount; byteIndex++)
whismanoid 0:3edb3708c8c5 2552 // {
whismanoid 0:3edb3708c8c5 2553 // cmdLine_DAPLINKserial.serial().printf(" 0x%2.2X", mosiData[byteIndex]);
whismanoid 0:3edb3708c8c5 2554 // }
whismanoid 0:3edb3708c8c5 2555 // // hex dump misoData[0..byteCount-1]
whismanoid 0:3edb3708c8c5 2556 // cmdLine_DAPLINKserial.serial().printf(" MISO<-");
whismanoid 0:3edb3708c8c5 2557 // for (unsigned int byteIndex = 0; byteIndex < numBytesTransferred; byteIndex++)
whismanoid 0:3edb3708c8c5 2558 // {
whismanoid 0:3edb3708c8c5 2559 // cmdLine_DAPLINKserial.serial().printf(" 0x%2.2X", misoData[byteIndex]);
whismanoid 0:3edb3708c8c5 2560 // }
whismanoid 0:3edb3708c8c5 2561 // cmdLine_DAPLINKserial.serial().printf(" ");
whismanoid 0:3edb3708c8c5 2562 //#endif
whismanoid 0:3edb3708c8c5 2563 // // VERIFY: DIAGNOSTIC: print MAX5715 device register write
whismanoid 0:3edb3708c8c5 2564 // // TODO: MAX5715_print_register_verbose(mosiData8_FF0000, mosiData16_00FFFF);
whismanoid 0:3edb3708c8c5 2565 // // TODO: print_verbose_SPI_diagnostic(mosiData16_FF00, mosiData16_00FF, misoData16_FF00, misoData16_00FF);
whismanoid 0:3edb3708c8c5 2566 // //
whismanoid 0:3edb3708c8c5 2567 // int misoData16 = (misoData[0] << 8) | misoData[1];
whismanoid 0:3edb3708c8c5 2568 // return misoData16;
whismanoid 0:3edb3708c8c5 2569 //}
whismanoid 0:3edb3708c8c5 2570
whismanoid 0:3edb3708c8c5 2571 #endif
whismanoid 0:3edb3708c8c5 2572
whismanoid 0:3edb3708c8c5 2573
whismanoid 0:3edb3708c8c5 2574 #if APPLICATION_MAX5171 // hardware interface functions
whismanoid 0:3edb3708c8c5 2575 #endif
whismanoid 0:3edb3708c8c5 2576
whismanoid 0:3edb3708c8c5 2577
whismanoid 0:3edb3708c8c5 2578 #if APPLICATION_MAX11410 // hardware interface functions
whismanoid 0:3edb3708c8c5 2579 #endif
whismanoid 0:3edb3708c8c5 2580
whismanoid 0:3edb3708c8c5 2581
whismanoid 0:3edb3708c8c5 2582 #if APPLICATION_MAX12345 // hardware interface functions
whismanoid 0:3edb3708c8c5 2583 #endif
whismanoid 0:3edb3708c8c5 2584
whismanoid 0:3edb3708c8c5 2585
whismanoid 0:3edb3708c8c5 2586 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 2587 // print banner message to serial port
whismanoid 0:3edb3708c8c5 2588 void print_banner()
whismanoid 0:3edb3708c8c5 2589 {
whismanoid 0:3edb3708c8c5 2590 #if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 2591 DAPLINKserial.printf("\r\n");
whismanoid 0:3edb3708c8c5 2592 # if defined(TARGET_MAX32630)
whismanoid 0:3edb3708c8c5 2593 DAPLINKserial.printf("MAX32630");
whismanoid 0:3edb3708c8c5 2594 # elif defined(TARGET_MAX32625MBED)
whismanoid 0:3edb3708c8c5 2595 DAPLINKserial.printf("MAX32625MBED");
whismanoid 0:3edb3708c8c5 2596 # elif defined(TARGET_NUCLEO_F446RE)
whismanoid 0:3edb3708c8c5 2597 DAPLINKserial.printf("NUCLEO_F446RE");
whismanoid 0:3edb3708c8c5 2598 # elif defined(TARGET_NUCLEO_F401RE)
whismanoid 0:3edb3708c8c5 2599 DAPLINKserial.printf("NUCLEO_F401RE");
whismanoid 0:3edb3708c8c5 2600 # elif defined(TARGET_LPC1768)
whismanoid 0:3edb3708c8c5 2601 DAPLINKserial.printf("LPC1768");
whismanoid 0:3edb3708c8c5 2602 # else
whismanoid 0:3edb3708c8c5 2603 // unknown target
whismanoid 0:3edb3708c8c5 2604 DAPLINKserial.printf("unknownTarget");
whismanoid 0:3edb3708c8c5 2605 # endif
whismanoid 0:3edb3708c8c5 2606 DAPLINKserial.printf(" DAPLINKserial\r\n");
whismanoid 0:3edb3708c8c5 2607 #endif // HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 2608
whismanoid 0:3edb3708c8c5 2609 #if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 2610 microUSBserial.printf("\r\n");
whismanoid 0:3edb3708c8c5 2611 # if defined(TARGET_MAX32630)
whismanoid 0:3edb3708c8c5 2612 microUSBserial.printf("MAX32630");
whismanoid 0:3edb3708c8c5 2613 # elif defined(TARGET_MAX32625MBED)
whismanoid 0:3edb3708c8c5 2614 microUSBserial.printf("MAX32625MBED");
whismanoid 0:3edb3708c8c5 2615 # elif defined(TARGET_NUCLEO_F446RE)
whismanoid 0:3edb3708c8c5 2616 microUSBserial.printf("NUCLEO_F446RE");
whismanoid 0:3edb3708c8c5 2617 # elif defined(TARGET_NUCLEO_F401RE)
whismanoid 0:3edb3708c8c5 2618 microUSBserial.printf("NUCLEO_F401RE");
whismanoid 0:3edb3708c8c5 2619 # elif defined(TARGET_LPC1768)
whismanoid 0:3edb3708c8c5 2620 microUSBserial.printf("LPC1768");
whismanoid 0:3edb3708c8c5 2621 # else
whismanoid 0:3edb3708c8c5 2622 // unknown target
whismanoid 0:3edb3708c8c5 2623 microUSBserial.printf("unknownTarget");
whismanoid 0:3edb3708c8c5 2624 # endif
whismanoid 0:3edb3708c8c5 2625 microUSBserial.printf(" microUSBserial\r\n");
whismanoid 0:3edb3708c8c5 2626 #endif // HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 2627 }
whismanoid 0:3edb3708c8c5 2628
whismanoid 0:3edb3708c8c5 2629 // DigitalInOut pin resource: print the pin index names to microUSBserial
whismanoid 0:3edb3708c8c5 2630 #if HAS_digitalInOuts
whismanoid 0:3edb3708c8c5 2631 void list_digitalInOutPins(Stream& serialStream)
whismanoid 0:3edb3708c8c5 2632 {
whismanoid 0:3edb3708c8c5 2633 #if HAS_digitalInOut0
whismanoid 0:3edb3708c8c5 2634 serialStream.printf(" 0");
whismanoid 0:3edb3708c8c5 2635 #endif
whismanoid 0:3edb3708c8c5 2636 #if HAS_digitalInOut1
whismanoid 0:3edb3708c8c5 2637 serialStream.printf(" 1");
whismanoid 0:3edb3708c8c5 2638 #endif
whismanoid 0:3edb3708c8c5 2639 #if HAS_digitalInOut2
whismanoid 0:3edb3708c8c5 2640 serialStream.printf(" 2");
whismanoid 0:3edb3708c8c5 2641 #endif
whismanoid 0:3edb3708c8c5 2642 #if HAS_digitalInOut3
whismanoid 0:3edb3708c8c5 2643 serialStream.printf(" 3");
whismanoid 0:3edb3708c8c5 2644 #endif
whismanoid 0:3edb3708c8c5 2645 #if HAS_digitalInOut4
whismanoid 0:3edb3708c8c5 2646 serialStream.printf(" 4");
whismanoid 0:3edb3708c8c5 2647 #endif
whismanoid 0:3edb3708c8c5 2648 #if HAS_digitalInOut5
whismanoid 0:3edb3708c8c5 2649 serialStream.printf(" 5");
whismanoid 0:3edb3708c8c5 2650 #endif
whismanoid 0:3edb3708c8c5 2651 #if HAS_digitalInOut6
whismanoid 0:3edb3708c8c5 2652 serialStream.printf(" 6");
whismanoid 0:3edb3708c8c5 2653 #endif
whismanoid 0:3edb3708c8c5 2654 #if HAS_digitalInOut7
whismanoid 0:3edb3708c8c5 2655 serialStream.printf(" 7");
whismanoid 0:3edb3708c8c5 2656 #endif
whismanoid 0:3edb3708c8c5 2657 #if HAS_digitalInOut8
whismanoid 0:3edb3708c8c5 2658 serialStream.printf(" 8");
whismanoid 0:3edb3708c8c5 2659 #endif
whismanoid 0:3edb3708c8c5 2660 #if HAS_digitalInOut9
whismanoid 0:3edb3708c8c5 2661 serialStream.printf(" 9");
whismanoid 0:3edb3708c8c5 2662 #endif
whismanoid 0:3edb3708c8c5 2663 #if HAS_digitalInOut10
whismanoid 0:3edb3708c8c5 2664 serialStream.printf(" 10");
whismanoid 0:3edb3708c8c5 2665 #endif
whismanoid 0:3edb3708c8c5 2666 #if HAS_digitalInOut11
whismanoid 0:3edb3708c8c5 2667 serialStream.printf(" 11");
whismanoid 0:3edb3708c8c5 2668 #endif
whismanoid 0:3edb3708c8c5 2669 #if HAS_digitalInOut12
whismanoid 0:3edb3708c8c5 2670 serialStream.printf(" 12");
whismanoid 0:3edb3708c8c5 2671 #endif
whismanoid 0:3edb3708c8c5 2672 #if HAS_digitalInOut13
whismanoid 0:3edb3708c8c5 2673 serialStream.printf(" 13");
whismanoid 0:3edb3708c8c5 2674 #endif
whismanoid 0:3edb3708c8c5 2675 #if HAS_digitalInOut14
whismanoid 0:3edb3708c8c5 2676 serialStream.printf(" 14");
whismanoid 0:3edb3708c8c5 2677 #endif
whismanoid 0:3edb3708c8c5 2678 #if HAS_digitalInOut15
whismanoid 0:3edb3708c8c5 2679 serialStream.printf(" 15");
whismanoid 0:3edb3708c8c5 2680 #endif
whismanoid 0:3edb3708c8c5 2681 #if HAS_digitalInOut16
whismanoid 0:3edb3708c8c5 2682 serialStream.printf(" 16");
whismanoid 0:3edb3708c8c5 2683 #endif
whismanoid 0:3edb3708c8c5 2684 #if HAS_digitalInOut17
whismanoid 0:3edb3708c8c5 2685 serialStream.printf(" 17");
whismanoid 0:3edb3708c8c5 2686 #endif
whismanoid 0:3edb3708c8c5 2687 }
whismanoid 0:3edb3708c8c5 2688 #endif
whismanoid 0:3edb3708c8c5 2689
whismanoid 0:3edb3708c8c5 2690 // DigitalInOut pin resource: present?
whismanoid 0:3edb3708c8c5 2691 #if HAS_digitalInOuts
whismanoid 0:3edb3708c8c5 2692 bool has_digitalInOutPin(int cPinIndex)
whismanoid 0:3edb3708c8c5 2693 {
whismanoid 0:3edb3708c8c5 2694 switch (cPinIndex)
whismanoid 0:3edb3708c8c5 2695 {
whismanoid 0:3edb3708c8c5 2696 #if HAS_digitalInOut0
whismanoid 0:3edb3708c8c5 2697 case '0': case 0x00: return true;
whismanoid 0:3edb3708c8c5 2698 #endif
whismanoid 0:3edb3708c8c5 2699 #if HAS_digitalInOut1
whismanoid 0:3edb3708c8c5 2700 case '1': case 0x01: return true;
whismanoid 0:3edb3708c8c5 2701 #endif
whismanoid 0:3edb3708c8c5 2702 #if HAS_digitalInOut2
whismanoid 0:3edb3708c8c5 2703 case '2': case 0x02: return true;
whismanoid 0:3edb3708c8c5 2704 #endif
whismanoid 0:3edb3708c8c5 2705 #if HAS_digitalInOut3
whismanoid 0:3edb3708c8c5 2706 case '3': case 0x03: return true;
whismanoid 0:3edb3708c8c5 2707 #endif
whismanoid 0:3edb3708c8c5 2708 #if HAS_digitalInOut4
whismanoid 0:3edb3708c8c5 2709 case '4': case 0x04: return true;
whismanoid 0:3edb3708c8c5 2710 #endif
whismanoid 0:3edb3708c8c5 2711 #if HAS_digitalInOut5
whismanoid 0:3edb3708c8c5 2712 case '5': case 0x05: return true;
whismanoid 0:3edb3708c8c5 2713 #endif
whismanoid 0:3edb3708c8c5 2714 #if HAS_digitalInOut6
whismanoid 0:3edb3708c8c5 2715 case '6': case 0x06: return true;
whismanoid 0:3edb3708c8c5 2716 #endif
whismanoid 0:3edb3708c8c5 2717 #if HAS_digitalInOut7
whismanoid 0:3edb3708c8c5 2718 case '7': case 0x07: return true;
whismanoid 0:3edb3708c8c5 2719 #endif
whismanoid 0:3edb3708c8c5 2720 #if HAS_digitalInOut8
whismanoid 0:3edb3708c8c5 2721 case '8': case 0x08: return true;
whismanoid 0:3edb3708c8c5 2722 #endif
whismanoid 0:3edb3708c8c5 2723 #if HAS_digitalInOut9
whismanoid 0:3edb3708c8c5 2724 case '9': case 0x09: return true;
whismanoid 0:3edb3708c8c5 2725 #endif
whismanoid 0:3edb3708c8c5 2726 #if HAS_digitalInOut10
whismanoid 0:3edb3708c8c5 2727 case 'a': case 0x0a: return true;
whismanoid 0:3edb3708c8c5 2728 #endif
whismanoid 0:3edb3708c8c5 2729 #if HAS_digitalInOut11
whismanoid 0:3edb3708c8c5 2730 case 'b': case 0x0b: return true;
whismanoid 0:3edb3708c8c5 2731 #endif
whismanoid 0:3edb3708c8c5 2732 #if HAS_digitalInOut12
whismanoid 0:3edb3708c8c5 2733 case 'c': case 0x0c: return true;
whismanoid 0:3edb3708c8c5 2734 #endif
whismanoid 0:3edb3708c8c5 2735 #if HAS_digitalInOut13
whismanoid 0:3edb3708c8c5 2736 case 'd': case 0x0d: return true;
whismanoid 0:3edb3708c8c5 2737 #endif
whismanoid 0:3edb3708c8c5 2738 #if HAS_digitalInOut14
whismanoid 0:3edb3708c8c5 2739 case 'e': case 0x0e: return true;
whismanoid 0:3edb3708c8c5 2740 #endif
whismanoid 0:3edb3708c8c5 2741 #if HAS_digitalInOut15
whismanoid 0:3edb3708c8c5 2742 case 'f': case 0x0f: return true;
whismanoid 0:3edb3708c8c5 2743 #endif
whismanoid 0:3edb3708c8c5 2744 default:
whismanoid 0:3edb3708c8c5 2745 return false;
whismanoid 0:3edb3708c8c5 2746 }
whismanoid 0:3edb3708c8c5 2747 }
whismanoid 0:3edb3708c8c5 2748 #endif
whismanoid 0:3edb3708c8c5 2749
whismanoid 0:3edb3708c8c5 2750 // DigitalInOut pin resource: search index
whismanoid 0:3edb3708c8c5 2751 #if HAS_digitalInOuts
whismanoid 0:3edb3708c8c5 2752 DigitalInOut& find_digitalInOutPin(int cPinIndex)
whismanoid 0:3edb3708c8c5 2753 {
whismanoid 0:3edb3708c8c5 2754 switch (cPinIndex)
whismanoid 0:3edb3708c8c5 2755 {
whismanoid 0:3edb3708c8c5 2756 default: // default to the first defined digitalInOut pin
whismanoid 0:3edb3708c8c5 2757 #if HAS_digitalInOut0
whismanoid 0:3edb3708c8c5 2758 case '0': case 0x00: return digitalInOut0;
whismanoid 0:3edb3708c8c5 2759 #endif
whismanoid 0:3edb3708c8c5 2760 #if HAS_digitalInOut1
whismanoid 0:3edb3708c8c5 2761 case '1': case 0x01: return digitalInOut1;
whismanoid 0:3edb3708c8c5 2762 #endif
whismanoid 0:3edb3708c8c5 2763 #if HAS_digitalInOut2
whismanoid 0:3edb3708c8c5 2764 case '2': case 0x02: return digitalInOut2;
whismanoid 0:3edb3708c8c5 2765 #endif
whismanoid 0:3edb3708c8c5 2766 #if HAS_digitalInOut3
whismanoid 0:3edb3708c8c5 2767 case '3': case 0x03: return digitalInOut3;
whismanoid 0:3edb3708c8c5 2768 #endif
whismanoid 0:3edb3708c8c5 2769 #if HAS_digitalInOut4
whismanoid 0:3edb3708c8c5 2770 case '4': case 0x04: return digitalInOut4;
whismanoid 0:3edb3708c8c5 2771 #endif
whismanoid 0:3edb3708c8c5 2772 #if HAS_digitalInOut5
whismanoid 0:3edb3708c8c5 2773 case '5': case 0x05: return digitalInOut5;
whismanoid 0:3edb3708c8c5 2774 #endif
whismanoid 0:3edb3708c8c5 2775 #if HAS_digitalInOut6
whismanoid 0:3edb3708c8c5 2776 case '6': case 0x06: return digitalInOut6;
whismanoid 0:3edb3708c8c5 2777 #endif
whismanoid 0:3edb3708c8c5 2778 #if HAS_digitalInOut7
whismanoid 0:3edb3708c8c5 2779 case '7': case 0x07: return digitalInOut7;
whismanoid 0:3edb3708c8c5 2780 #endif
whismanoid 0:3edb3708c8c5 2781 #if HAS_digitalInOut8
whismanoid 0:3edb3708c8c5 2782 case '8': case 0x08: return digitalInOut8;
whismanoid 0:3edb3708c8c5 2783 #endif
whismanoid 0:3edb3708c8c5 2784 #if HAS_digitalInOut9
whismanoid 0:3edb3708c8c5 2785 case '9': case 0x09: return digitalInOut9;
whismanoid 0:3edb3708c8c5 2786 #endif
whismanoid 0:3edb3708c8c5 2787 #if HAS_digitalInOut10
whismanoid 0:3edb3708c8c5 2788 case 'a': case 0x0a: return digitalInOut10;
whismanoid 0:3edb3708c8c5 2789 #endif
whismanoid 0:3edb3708c8c5 2790 #if HAS_digitalInOut11
whismanoid 0:3edb3708c8c5 2791 case 'b': case 0x0b: return digitalInOut11;
whismanoid 0:3edb3708c8c5 2792 #endif
whismanoid 0:3edb3708c8c5 2793 #if HAS_digitalInOut12
whismanoid 0:3edb3708c8c5 2794 case 'c': case 0x0c: return digitalInOut12;
whismanoid 0:3edb3708c8c5 2795 #endif
whismanoid 0:3edb3708c8c5 2796 #if HAS_digitalInOut13
whismanoid 0:3edb3708c8c5 2797 case 'd': case 0x0d: return digitalInOut13;
whismanoid 0:3edb3708c8c5 2798 #endif
whismanoid 0:3edb3708c8c5 2799 #if HAS_digitalInOut14
whismanoid 0:3edb3708c8c5 2800 case 'e': case 0x0e: return digitalInOut14;
whismanoid 0:3edb3708c8c5 2801 #endif
whismanoid 0:3edb3708c8c5 2802 #if HAS_digitalInOut15
whismanoid 0:3edb3708c8c5 2803 case 'f': case 0x0f: return digitalInOut15;
whismanoid 0:3edb3708c8c5 2804 #endif
whismanoid 0:3edb3708c8c5 2805 #if HAS_digitalInOut16
whismanoid 0:3edb3708c8c5 2806 case 'g': case 0x10: return digitalInOut16;
whismanoid 0:3edb3708c8c5 2807 #endif
whismanoid 0:3edb3708c8c5 2808 #if HAS_digitalInOut17
whismanoid 0:3edb3708c8c5 2809 case 'h': case 0x11: return digitalInOut17;
whismanoid 0:3edb3708c8c5 2810 #endif
whismanoid 0:3edb3708c8c5 2811 }
whismanoid 0:3edb3708c8c5 2812 }
whismanoid 0:3edb3708c8c5 2813 #endif
whismanoid 0:3edb3708c8c5 2814
whismanoid 0:3edb3708c8c5 2815 // AnalogIn pin resource: print the pin index names to microUSBserial
whismanoid 0:3edb3708c8c5 2816 #if HAS_analogIns
whismanoid 0:3edb3708c8c5 2817 void list_analogInPins(Stream& serialStream)
whismanoid 0:3edb3708c8c5 2818 {
whismanoid 0:3edb3708c8c5 2819 #if HAS_analogIn0
whismanoid 0:3edb3708c8c5 2820 serialStream.printf(" 0");
whismanoid 0:3edb3708c8c5 2821 #endif
whismanoid 0:3edb3708c8c5 2822 #if HAS_analogIn1
whismanoid 0:3edb3708c8c5 2823 serialStream.printf(" 1");
whismanoid 0:3edb3708c8c5 2824 #endif
whismanoid 0:3edb3708c8c5 2825 #if HAS_analogIn2
whismanoid 0:3edb3708c8c5 2826 serialStream.printf(" 2");
whismanoid 0:3edb3708c8c5 2827 #endif
whismanoid 0:3edb3708c8c5 2828 #if HAS_analogIn3
whismanoid 0:3edb3708c8c5 2829 serialStream.printf(" 3");
whismanoid 0:3edb3708c8c5 2830 #endif
whismanoid 0:3edb3708c8c5 2831 #if HAS_analogIn4
whismanoid 0:3edb3708c8c5 2832 serialStream.printf(" 4");
whismanoid 0:3edb3708c8c5 2833 #endif
whismanoid 0:3edb3708c8c5 2834 #if HAS_analogIn5
whismanoid 0:3edb3708c8c5 2835 serialStream.printf(" 5");
whismanoid 0:3edb3708c8c5 2836 #endif
whismanoid 0:3edb3708c8c5 2837 #if HAS_analogIn6
whismanoid 0:3edb3708c8c5 2838 serialStream.printf(" 6");
whismanoid 0:3edb3708c8c5 2839 #endif
whismanoid 0:3edb3708c8c5 2840 #if HAS_analogIn7
whismanoid 0:3edb3708c8c5 2841 serialStream.printf(" 7");
whismanoid 0:3edb3708c8c5 2842 #endif
whismanoid 0:3edb3708c8c5 2843 #if HAS_analogIn8
whismanoid 0:3edb3708c8c5 2844 serialStream.printf(" 8");
whismanoid 0:3edb3708c8c5 2845 #endif
whismanoid 0:3edb3708c8c5 2846 #if HAS_analogIn9
whismanoid 0:3edb3708c8c5 2847 serialStream.printf(" 9");
whismanoid 0:3edb3708c8c5 2848 #endif
whismanoid 0:3edb3708c8c5 2849 #if HAS_analogIn10
whismanoid 0:3edb3708c8c5 2850 serialStream.printf(" a");
whismanoid 0:3edb3708c8c5 2851 #endif
whismanoid 0:3edb3708c8c5 2852 #if HAS_analogIn11
whismanoid 0:3edb3708c8c5 2853 serialStream.printf(" b");
whismanoid 0:3edb3708c8c5 2854 #endif
whismanoid 0:3edb3708c8c5 2855 #if HAS_analogIn12
whismanoid 0:3edb3708c8c5 2856 serialStream.printf(" c");
whismanoid 0:3edb3708c8c5 2857 #endif
whismanoid 0:3edb3708c8c5 2858 #if HAS_analogIn13
whismanoid 0:3edb3708c8c5 2859 serialStream.printf(" d");
whismanoid 0:3edb3708c8c5 2860 #endif
whismanoid 0:3edb3708c8c5 2861 #if HAS_analogIn14
whismanoid 0:3edb3708c8c5 2862 serialStream.printf(" e");
whismanoid 0:3edb3708c8c5 2863 #endif
whismanoid 0:3edb3708c8c5 2864 #if HAS_analogIn15
whismanoid 0:3edb3708c8c5 2865 serialStream.printf(" f");
whismanoid 0:3edb3708c8c5 2866 #endif
whismanoid 0:3edb3708c8c5 2867 }
whismanoid 0:3edb3708c8c5 2868 #endif
whismanoid 0:3edb3708c8c5 2869
whismanoid 0:3edb3708c8c5 2870 // AnalogIn pin resource: present?
whismanoid 0:3edb3708c8c5 2871 #if HAS_analogIns
whismanoid 0:3edb3708c8c5 2872 bool has_analogInPin(int cPinIndex)
whismanoid 0:3edb3708c8c5 2873 {
whismanoid 0:3edb3708c8c5 2874 switch (cPinIndex)
whismanoid 0:3edb3708c8c5 2875 {
whismanoid 0:3edb3708c8c5 2876 #if HAS_analogIn0
whismanoid 0:3edb3708c8c5 2877 case '0': case 0x00: return true;
whismanoid 0:3edb3708c8c5 2878 #endif
whismanoid 0:3edb3708c8c5 2879 #if HAS_analogIn1
whismanoid 0:3edb3708c8c5 2880 case '1': case 0x01: return true;
whismanoid 0:3edb3708c8c5 2881 #endif
whismanoid 0:3edb3708c8c5 2882 #if HAS_analogIn2
whismanoid 0:3edb3708c8c5 2883 case '2': case 0x02: return true;
whismanoid 0:3edb3708c8c5 2884 #endif
whismanoid 0:3edb3708c8c5 2885 #if HAS_analogIn3
whismanoid 0:3edb3708c8c5 2886 case '3': case 0x03: return true;
whismanoid 0:3edb3708c8c5 2887 #endif
whismanoid 0:3edb3708c8c5 2888 #if HAS_analogIn4
whismanoid 0:3edb3708c8c5 2889 case '4': case 0x04: return true;
whismanoid 0:3edb3708c8c5 2890 #endif
whismanoid 0:3edb3708c8c5 2891 #if HAS_analogIn5
whismanoid 0:3edb3708c8c5 2892 case '5': case 0x05: return true;
whismanoid 0:3edb3708c8c5 2893 #endif
whismanoid 0:3edb3708c8c5 2894 #if HAS_analogIn6
whismanoid 0:3edb3708c8c5 2895 case '6': case 0x06: return true;
whismanoid 0:3edb3708c8c5 2896 #endif
whismanoid 0:3edb3708c8c5 2897 #if HAS_analogIn7
whismanoid 0:3edb3708c8c5 2898 case '7': case 0x07: return true;
whismanoid 0:3edb3708c8c5 2899 #endif
whismanoid 0:3edb3708c8c5 2900 #if HAS_analogIn8
whismanoid 0:3edb3708c8c5 2901 case '8': case 0x08: return true;
whismanoid 0:3edb3708c8c5 2902 #endif
whismanoid 0:3edb3708c8c5 2903 #if HAS_analogIn9
whismanoid 0:3edb3708c8c5 2904 case '9': case 0x09: return true;
whismanoid 0:3edb3708c8c5 2905 #endif
whismanoid 0:3edb3708c8c5 2906 #if HAS_analogIn10
whismanoid 0:3edb3708c8c5 2907 case 'a': case 0x0a: return true;
whismanoid 0:3edb3708c8c5 2908 #endif
whismanoid 0:3edb3708c8c5 2909 #if HAS_analogIn11
whismanoid 0:3edb3708c8c5 2910 case 'b': case 0x0b: return true;
whismanoid 0:3edb3708c8c5 2911 #endif
whismanoid 0:3edb3708c8c5 2912 #if HAS_analogIn12
whismanoid 0:3edb3708c8c5 2913 case 'c': case 0x0c: return true;
whismanoid 0:3edb3708c8c5 2914 #endif
whismanoid 0:3edb3708c8c5 2915 #if HAS_analogIn13
whismanoid 0:3edb3708c8c5 2916 case 'd': case 0x0d: return true;
whismanoid 0:3edb3708c8c5 2917 #endif
whismanoid 0:3edb3708c8c5 2918 #if HAS_analogIn14
whismanoid 0:3edb3708c8c5 2919 case 'e': case 0x0e: return true;
whismanoid 0:3edb3708c8c5 2920 #endif
whismanoid 0:3edb3708c8c5 2921 #if HAS_analogIn15
whismanoid 0:3edb3708c8c5 2922 case 'f': case 0x0f: return true;
whismanoid 0:3edb3708c8c5 2923 #endif
whismanoid 0:3edb3708c8c5 2924 default:
whismanoid 0:3edb3708c8c5 2925 return false;
whismanoid 0:3edb3708c8c5 2926 }
whismanoid 0:3edb3708c8c5 2927 }
whismanoid 0:3edb3708c8c5 2928 #endif
whismanoid 0:3edb3708c8c5 2929
whismanoid 0:3edb3708c8c5 2930 // AnalogIn pin resource: search index
whismanoid 0:3edb3708c8c5 2931 #if HAS_analogIns
whismanoid 0:3edb3708c8c5 2932 AnalogIn& find_analogInPin(int cPinIndex)
whismanoid 0:3edb3708c8c5 2933 {
whismanoid 0:3edb3708c8c5 2934 switch (cPinIndex)
whismanoid 0:3edb3708c8c5 2935 {
whismanoid 0:3edb3708c8c5 2936 default: // default to the first defined analogIn pin
whismanoid 0:3edb3708c8c5 2937 #if HAS_analogIn0
whismanoid 0:3edb3708c8c5 2938 case '0': case 0x00: return analogIn0;
whismanoid 0:3edb3708c8c5 2939 #endif
whismanoid 0:3edb3708c8c5 2940 #if HAS_analogIn1
whismanoid 0:3edb3708c8c5 2941 case '1': case 0x01: return analogIn1;
whismanoid 0:3edb3708c8c5 2942 #endif
whismanoid 0:3edb3708c8c5 2943 #if HAS_analogIn2
whismanoid 0:3edb3708c8c5 2944 case '2': case 0x02: return analogIn2;
whismanoid 0:3edb3708c8c5 2945 #endif
whismanoid 0:3edb3708c8c5 2946 #if HAS_analogIn3
whismanoid 0:3edb3708c8c5 2947 case '3': case 0x03: return analogIn3;
whismanoid 0:3edb3708c8c5 2948 #endif
whismanoid 0:3edb3708c8c5 2949 #if HAS_analogIn4
whismanoid 0:3edb3708c8c5 2950 case '4': case 0x04: return analogIn4;
whismanoid 0:3edb3708c8c5 2951 #endif
whismanoid 0:3edb3708c8c5 2952 #if HAS_analogIn5
whismanoid 0:3edb3708c8c5 2953 case '5': case 0x05: return analogIn5;
whismanoid 0:3edb3708c8c5 2954 #endif
whismanoid 0:3edb3708c8c5 2955 #if HAS_analogIn6
whismanoid 0:3edb3708c8c5 2956 case '6': case 0x06: return analogIn6;
whismanoid 0:3edb3708c8c5 2957 #endif
whismanoid 0:3edb3708c8c5 2958 #if HAS_analogIn7
whismanoid 0:3edb3708c8c5 2959 case '7': case 0x07: return analogIn7;
whismanoid 0:3edb3708c8c5 2960 #endif
whismanoid 0:3edb3708c8c5 2961 #if HAS_analogIn8
whismanoid 0:3edb3708c8c5 2962 case '8': case 0x08: return analogIn8;
whismanoid 0:3edb3708c8c5 2963 #endif
whismanoid 0:3edb3708c8c5 2964 #if HAS_analogIn9
whismanoid 0:3edb3708c8c5 2965 case '9': case 0x09: return analogIn9;
whismanoid 0:3edb3708c8c5 2966 #endif
whismanoid 0:3edb3708c8c5 2967 #if HAS_analogIn10
whismanoid 0:3edb3708c8c5 2968 case 'a': case 0x0a: return analogIn10;
whismanoid 0:3edb3708c8c5 2969 #endif
whismanoid 0:3edb3708c8c5 2970 #if HAS_analogIn11
whismanoid 0:3edb3708c8c5 2971 case 'b': case 0x0b: return analogIn11;
whismanoid 0:3edb3708c8c5 2972 #endif
whismanoid 0:3edb3708c8c5 2973 #if HAS_analogIn12
whismanoid 0:3edb3708c8c5 2974 case 'c': case 0x0c: return analogIn12;
whismanoid 0:3edb3708c8c5 2975 #endif
whismanoid 0:3edb3708c8c5 2976 #if HAS_analogIn13
whismanoid 0:3edb3708c8c5 2977 case 'd': case 0x0d: return analogIn13;
whismanoid 0:3edb3708c8c5 2978 #endif
whismanoid 0:3edb3708c8c5 2979 #if HAS_analogIn14
whismanoid 0:3edb3708c8c5 2980 case 'e': case 0x0e: return analogIn14;
whismanoid 0:3edb3708c8c5 2981 #endif
whismanoid 0:3edb3708c8c5 2982 #if HAS_analogIn15
whismanoid 0:3edb3708c8c5 2983 case 'f': case 0x0f: return analogIn15;
whismanoid 0:3edb3708c8c5 2984 #endif
whismanoid 0:3edb3708c8c5 2985 }
whismanoid 0:3edb3708c8c5 2986 }
whismanoid 0:3edb3708c8c5 2987 #endif
whismanoid 0:3edb3708c8c5 2988
whismanoid 0:3edb3708c8c5 2989 #if HAS_analogIns
whismanoid 0:3edb3708c8c5 2990 const float analogInPin_fullScaleVoltage[] = {
whismanoid 0:3edb3708c8c5 2991 # if defined(TARGET_MAX32630)
whismanoid 0:3edb3708c8c5 2992 ADC_FULL_SCALE_VOLTAGE, // analogIn0
whismanoid 0:3edb3708c8c5 2993 ADC_FULL_SCALE_VOLTAGE, // analogIn1
whismanoid 0:3edb3708c8c5 2994 ADC_FULL_SCALE_VOLTAGE, // analogIn2
whismanoid 0:3edb3708c8c5 2995 ADC_FULL_SCALE_VOLTAGE, // analogIn3
whismanoid 0:3edb3708c8c5 2996 ADC_FULL_SCALE_VOLTAGE * 5.0f, // analogIn4 // AIN_4 = AIN0 / 5.0 fullscale is 6.0V
whismanoid 0:3edb3708c8c5 2997 ADC_FULL_SCALE_VOLTAGE * 5.0f, // analogIn4 // AIN_5 = AIN1 / 5.0 fullscale is 6.0V
whismanoid 0:3edb3708c8c5 2998 ADC_FULL_SCALE_VOLTAGE * 4.0f, // analogIn6 // AIN_6 = VDDB / 4.0 fullscale is 4.8V
whismanoid 0:3edb3708c8c5 2999 ADC_FULL_SCALE_VOLTAGE, // analogIn7 // AIN_7 = VDD18 fullscale is 1.2V
whismanoid 0:3edb3708c8c5 3000 ADC_FULL_SCALE_VOLTAGE, // analogIn8 // AIN_8 = VDD12 fullscale is 1.2V
whismanoid 0:3edb3708c8c5 3001 ADC_FULL_SCALE_VOLTAGE * 2.0f, // analogIn9 // AIN_9 = VRTC / 2.0 fullscale is 2.4V
whismanoid 0:3edb3708c8c5 3002 ADC_FULL_SCALE_VOLTAGE, // analogIn10 // AIN_10 = x undefined?
whismanoid 0:3edb3708c8c5 3003 ADC_FULL_SCALE_VOLTAGE * 4.0f, // analogIn11 // AIN_11 = VDDIO / 4.0 fullscale is 4.8V
whismanoid 0:3edb3708c8c5 3004 ADC_FULL_SCALE_VOLTAGE * 4.0f, // analogIn12 // AIN_12 = VDDIOH / 4.0 fullscale is 4.8V
whismanoid 0:3edb3708c8c5 3005 ADC_FULL_SCALE_VOLTAGE, // analogIn13
whismanoid 0:3edb3708c8c5 3006 ADC_FULL_SCALE_VOLTAGE, // analogIn14
whismanoid 0:3edb3708c8c5 3007 ADC_FULL_SCALE_VOLTAGE // analogIn15
whismanoid 0:3edb3708c8c5 3008 #elif defined(TARGET_MAX32625MBED)
whismanoid 0:3edb3708c8c5 3009 ADC_FULL_SCALE_VOLTAGE * 1.0f, // analogIn0 // fullscale is 1.2V
whismanoid 0:3edb3708c8c5 3010 ADC_FULL_SCALE_VOLTAGE * 1.0f, // analogIn1 // fullscale is 1.2V
whismanoid 0:3edb3708c8c5 3011 ADC_FULL_SCALE_VOLTAGE * 1.0f, // analogIn2 // fullscale is 1.2V
whismanoid 0:3edb3708c8c5 3012 ADC_FULL_SCALE_VOLTAGE * 1.0f, // analogIn3 // fullscale is 1.2V
whismanoid 0:3edb3708c8c5 3013 ADC_FULL_SCALE_VOLTAGE * 5.0f, // analogIn4 // AIN_4 = AIN0 / 5.0 fullscale is 6.0V
whismanoid 0:3edb3708c8c5 3014 ADC_FULL_SCALE_VOLTAGE * 5.0f, // analogIn4 // AIN_5 = AIN1 / 5.0 fullscale is 6.0V
whismanoid 0:3edb3708c8c5 3015 ADC_FULL_SCALE_VOLTAGE * 4.0f, // analogIn6 // AIN_6 = VDDB / 4.0 fullscale is 4.8V
whismanoid 0:3edb3708c8c5 3016 ADC_FULL_SCALE_VOLTAGE, // analogIn7 // AIN_7 = VDD18 fullscale is 1.2V
whismanoid 0:3edb3708c8c5 3017 ADC_FULL_SCALE_VOLTAGE, // analogIn8 // AIN_8 = VDD12 fullscale is 1.2V
whismanoid 0:3edb3708c8c5 3018 ADC_FULL_SCALE_VOLTAGE * 2.0f, // analogIn9 // AIN_9 = VRTC / 2.0 fullscale is 2.4V
whismanoid 0:3edb3708c8c5 3019 ADC_FULL_SCALE_VOLTAGE, // analogIn10 // AIN_10 = x undefined?
whismanoid 0:3edb3708c8c5 3020 ADC_FULL_SCALE_VOLTAGE * 4.0f, // analogIn11 // AIN_11 = VDDIO / 4.0 fullscale is 4.8V
whismanoid 0:3edb3708c8c5 3021 ADC_FULL_SCALE_VOLTAGE * 4.0f, // analogIn12 // AIN_12 = VDDIOH / 4.0 fullscale is 4.8V
whismanoid 0:3edb3708c8c5 3022 ADC_FULL_SCALE_VOLTAGE, // analogIn13
whismanoid 0:3edb3708c8c5 3023 ADC_FULL_SCALE_VOLTAGE, // analogIn14
whismanoid 0:3edb3708c8c5 3024 ADC_FULL_SCALE_VOLTAGE // analogIn15
whismanoid 0:3edb3708c8c5 3025 #elif defined(TARGET_NUCLEO_F446RE)
whismanoid 0:3edb3708c8c5 3026 ADC_FULL_SCALE_VOLTAGE, // analogIn0
whismanoid 0:3edb3708c8c5 3027 ADC_FULL_SCALE_VOLTAGE, // analogIn1
whismanoid 0:3edb3708c8c5 3028 ADC_FULL_SCALE_VOLTAGE, // analogIn2
whismanoid 0:3edb3708c8c5 3029 ADC_FULL_SCALE_VOLTAGE, // analogIn3
whismanoid 0:3edb3708c8c5 3030 ADC_FULL_SCALE_VOLTAGE, // analogIn4
whismanoid 0:3edb3708c8c5 3031 ADC_FULL_SCALE_VOLTAGE, // analogIn5
whismanoid 0:3edb3708c8c5 3032 ADC_FULL_SCALE_VOLTAGE, // analogIn6
whismanoid 0:3edb3708c8c5 3033 ADC_FULL_SCALE_VOLTAGE, // analogIn7
whismanoid 0:3edb3708c8c5 3034 ADC_FULL_SCALE_VOLTAGE, // analogIn8
whismanoid 0:3edb3708c8c5 3035 ADC_FULL_SCALE_VOLTAGE, // analogIn9
whismanoid 0:3edb3708c8c5 3036 ADC_FULL_SCALE_VOLTAGE, // analogIn10
whismanoid 0:3edb3708c8c5 3037 ADC_FULL_SCALE_VOLTAGE, // analogIn11
whismanoid 0:3edb3708c8c5 3038 ADC_FULL_SCALE_VOLTAGE, // analogIn12
whismanoid 0:3edb3708c8c5 3039 ADC_FULL_SCALE_VOLTAGE, // analogIn13
whismanoid 0:3edb3708c8c5 3040 ADC_FULL_SCALE_VOLTAGE, // analogIn14
whismanoid 0:3edb3708c8c5 3041 ADC_FULL_SCALE_VOLTAGE // analogIn15
whismanoid 0:3edb3708c8c5 3042 #elif defined(TARGET_NUCLEO_F401RE)
whismanoid 0:3edb3708c8c5 3043 ADC_FULL_SCALE_VOLTAGE, // analogIn0
whismanoid 0:3edb3708c8c5 3044 ADC_FULL_SCALE_VOLTAGE, // analogIn1
whismanoid 0:3edb3708c8c5 3045 ADC_FULL_SCALE_VOLTAGE, // analogIn2
whismanoid 0:3edb3708c8c5 3046 ADC_FULL_SCALE_VOLTAGE, // analogIn3
whismanoid 0:3edb3708c8c5 3047 ADC_FULL_SCALE_VOLTAGE, // analogIn4
whismanoid 0:3edb3708c8c5 3048 ADC_FULL_SCALE_VOLTAGE, // analogIn5
whismanoid 0:3edb3708c8c5 3049 ADC_FULL_SCALE_VOLTAGE, // analogIn6
whismanoid 0:3edb3708c8c5 3050 ADC_FULL_SCALE_VOLTAGE, // analogIn7
whismanoid 0:3edb3708c8c5 3051 ADC_FULL_SCALE_VOLTAGE, // analogIn8
whismanoid 0:3edb3708c8c5 3052 ADC_FULL_SCALE_VOLTAGE, // analogIn9
whismanoid 0:3edb3708c8c5 3053 ADC_FULL_SCALE_VOLTAGE, // analogIn10
whismanoid 0:3edb3708c8c5 3054 ADC_FULL_SCALE_VOLTAGE, // analogIn11
whismanoid 0:3edb3708c8c5 3055 ADC_FULL_SCALE_VOLTAGE, // analogIn12
whismanoid 0:3edb3708c8c5 3056 ADC_FULL_SCALE_VOLTAGE, // analogIn13
whismanoid 0:3edb3708c8c5 3057 ADC_FULL_SCALE_VOLTAGE, // analogIn14
whismanoid 0:3edb3708c8c5 3058 ADC_FULL_SCALE_VOLTAGE // analogIn15
whismanoid 0:3edb3708c8c5 3059 //#elif defined(TARGET_LPC1768)
whismanoid 0:3edb3708c8c5 3060 #else
whismanoid 0:3edb3708c8c5 3061 // unknown target
whismanoid 0:3edb3708c8c5 3062 ADC_FULL_SCALE_VOLTAGE, // analogIn0
whismanoid 0:3edb3708c8c5 3063 ADC_FULL_SCALE_VOLTAGE, // analogIn1
whismanoid 0:3edb3708c8c5 3064 ADC_FULL_SCALE_VOLTAGE, // analogIn2
whismanoid 0:3edb3708c8c5 3065 ADC_FULL_SCALE_VOLTAGE, // analogIn3
whismanoid 0:3edb3708c8c5 3066 ADC_FULL_SCALE_VOLTAGE, // analogIn4
whismanoid 0:3edb3708c8c5 3067 ADC_FULL_SCALE_VOLTAGE, // analogIn5
whismanoid 0:3edb3708c8c5 3068 ADC_FULL_SCALE_VOLTAGE, // analogIn6
whismanoid 0:3edb3708c8c5 3069 ADC_FULL_SCALE_VOLTAGE, // analogIn7
whismanoid 0:3edb3708c8c5 3070 ADC_FULL_SCALE_VOLTAGE, // analogIn8
whismanoid 0:3edb3708c8c5 3071 ADC_FULL_SCALE_VOLTAGE, // analogIn9
whismanoid 0:3edb3708c8c5 3072 ADC_FULL_SCALE_VOLTAGE, // analogIn10
whismanoid 0:3edb3708c8c5 3073 ADC_FULL_SCALE_VOLTAGE, // analogIn11
whismanoid 0:3edb3708c8c5 3074 ADC_FULL_SCALE_VOLTAGE, // analogIn12
whismanoid 0:3edb3708c8c5 3075 ADC_FULL_SCALE_VOLTAGE, // analogIn13
whismanoid 0:3edb3708c8c5 3076 ADC_FULL_SCALE_VOLTAGE, // analogIn14
whismanoid 0:3edb3708c8c5 3077 ADC_FULL_SCALE_VOLTAGE // analogIn15
whismanoid 0:3edb3708c8c5 3078 # endif
whismanoid 0:3edb3708c8c5 3079 };
whismanoid 0:3edb3708c8c5 3080 #endif
whismanoid 0:3edb3708c8c5 3081
whismanoid 0:3edb3708c8c5 3082 // PwmOut pin resource: print the pin index names to microUSBserial
whismanoid 0:3edb3708c8c5 3083 #if HAS_pwmDrivers
whismanoid 0:3edb3708c8c5 3084 void list_pwmDriverPins(Stream& serialStream)
whismanoid 0:3edb3708c8c5 3085 {
whismanoid 0:3edb3708c8c5 3086 #if HAS_pwmDriver0
whismanoid 0:3edb3708c8c5 3087 serialStream.printf(" 0");
whismanoid 0:3edb3708c8c5 3088 #endif
whismanoid 0:3edb3708c8c5 3089 #if HAS_pwmDriver1
whismanoid 0:3edb3708c8c5 3090 serialStream.printf(" 1");
whismanoid 0:3edb3708c8c5 3091 #endif
whismanoid 0:3edb3708c8c5 3092 #if HAS_pwmDriver2
whismanoid 0:3edb3708c8c5 3093 serialStream.printf(" 2");
whismanoid 0:3edb3708c8c5 3094 #endif
whismanoid 0:3edb3708c8c5 3095 #if HAS_pwmDriver3
whismanoid 0:3edb3708c8c5 3096 serialStream.printf(" 3");
whismanoid 0:3edb3708c8c5 3097 #endif
whismanoid 0:3edb3708c8c5 3098 #if HAS_pwmDriver4
whismanoid 0:3edb3708c8c5 3099 serialStream.printf(" 4");
whismanoid 0:3edb3708c8c5 3100 #endif
whismanoid 0:3edb3708c8c5 3101 #if HAS_pwmDriver5
whismanoid 0:3edb3708c8c5 3102 serialStream.printf(" 5");
whismanoid 0:3edb3708c8c5 3103 #endif
whismanoid 0:3edb3708c8c5 3104 #if HAS_pwmDriver6
whismanoid 0:3edb3708c8c5 3105 serialStream.printf(" 6");
whismanoid 0:3edb3708c8c5 3106 #endif
whismanoid 0:3edb3708c8c5 3107 #if HAS_pwmDriver7
whismanoid 0:3edb3708c8c5 3108 serialStream.printf(" 7");
whismanoid 0:3edb3708c8c5 3109 #endif
whismanoid 0:3edb3708c8c5 3110 #if HAS_pwmDriver8
whismanoid 0:3edb3708c8c5 3111 serialStream.printf(" 8");
whismanoid 0:3edb3708c8c5 3112 #endif
whismanoid 0:3edb3708c8c5 3113 #if HAS_pwmDriver9
whismanoid 0:3edb3708c8c5 3114 serialStream.printf(" 9");
whismanoid 0:3edb3708c8c5 3115 #endif
whismanoid 0:3edb3708c8c5 3116 #if HAS_pwmDriver10
whismanoid 0:3edb3708c8c5 3117 serialStream.printf(" a");
whismanoid 0:3edb3708c8c5 3118 #endif
whismanoid 0:3edb3708c8c5 3119 #if HAS_pwmDriver11
whismanoid 0:3edb3708c8c5 3120 serialStream.printf(" b");
whismanoid 0:3edb3708c8c5 3121 #endif
whismanoid 0:3edb3708c8c5 3122 #if HAS_pwmDriver12
whismanoid 0:3edb3708c8c5 3123 serialStream.printf(" c");
whismanoid 0:3edb3708c8c5 3124 #endif
whismanoid 0:3edb3708c8c5 3125 #if HAS_pwmDriver13
whismanoid 0:3edb3708c8c5 3126 serialStream.printf(" d");
whismanoid 0:3edb3708c8c5 3127 #endif
whismanoid 0:3edb3708c8c5 3128 #if HAS_pwmDriver14
whismanoid 0:3edb3708c8c5 3129 serialStream.printf(" e");
whismanoid 0:3edb3708c8c5 3130 #endif
whismanoid 0:3edb3708c8c5 3131 #if HAS_pwmDriver15
whismanoid 0:3edb3708c8c5 3132 serialStream.printf(" f");
whismanoid 0:3edb3708c8c5 3133 #endif
whismanoid 0:3edb3708c8c5 3134 }
whismanoid 0:3edb3708c8c5 3135 #endif
whismanoid 0:3edb3708c8c5 3136
whismanoid 0:3edb3708c8c5 3137 // PwmOut pin resource: present?
whismanoid 0:3edb3708c8c5 3138 #if HAS_pwmDrivers
whismanoid 0:3edb3708c8c5 3139 bool has_pwmDriverPin(int cPinIndex)
whismanoid 0:3edb3708c8c5 3140 {
whismanoid 0:3edb3708c8c5 3141 switch (cPinIndex)
whismanoid 0:3edb3708c8c5 3142 {
whismanoid 0:3edb3708c8c5 3143 #if HAS_pwmDriver0
whismanoid 0:3edb3708c8c5 3144 case '0': case 0x00: return true;
whismanoid 0:3edb3708c8c5 3145 #endif
whismanoid 0:3edb3708c8c5 3146 #if HAS_pwmDriver1
whismanoid 0:3edb3708c8c5 3147 case '1': case 0x01: return true;
whismanoid 0:3edb3708c8c5 3148 #endif
whismanoid 0:3edb3708c8c5 3149 #if HAS_pwmDriver2
whismanoid 0:3edb3708c8c5 3150 case '2': case 0x02: return true;
whismanoid 0:3edb3708c8c5 3151 #endif
whismanoid 0:3edb3708c8c5 3152 #if HAS_pwmDriver3
whismanoid 0:3edb3708c8c5 3153 case '3': case 0x03: return true;
whismanoid 0:3edb3708c8c5 3154 #endif
whismanoid 0:3edb3708c8c5 3155 #if HAS_pwmDriver4
whismanoid 0:3edb3708c8c5 3156 case '4': case 0x04: return true;
whismanoid 0:3edb3708c8c5 3157 #endif
whismanoid 0:3edb3708c8c5 3158 #if HAS_pwmDriver5
whismanoid 0:3edb3708c8c5 3159 case '5': case 0x05: return true;
whismanoid 0:3edb3708c8c5 3160 #endif
whismanoid 0:3edb3708c8c5 3161 #if HAS_pwmDriver6
whismanoid 0:3edb3708c8c5 3162 case '6': case 0x06: return true;
whismanoid 0:3edb3708c8c5 3163 #endif
whismanoid 0:3edb3708c8c5 3164 #if HAS_pwmDriver7
whismanoid 0:3edb3708c8c5 3165 case '7': case 0x07: return true;
whismanoid 0:3edb3708c8c5 3166 #endif
whismanoid 0:3edb3708c8c5 3167 #if HAS_pwmDriver8
whismanoid 0:3edb3708c8c5 3168 case '8': case 0x08: return true;
whismanoid 0:3edb3708c8c5 3169 #endif
whismanoid 0:3edb3708c8c5 3170 #if HAS_pwmDriver9
whismanoid 0:3edb3708c8c5 3171 case '9': case 0x09: return true;
whismanoid 0:3edb3708c8c5 3172 #endif
whismanoid 0:3edb3708c8c5 3173 #if HAS_pwmDriver10
whismanoid 0:3edb3708c8c5 3174 case 'a': case 0x0a: return true;
whismanoid 0:3edb3708c8c5 3175 #endif
whismanoid 0:3edb3708c8c5 3176 #if HAS_pwmDriver11
whismanoid 0:3edb3708c8c5 3177 case 'b': case 0x0b: return true;
whismanoid 0:3edb3708c8c5 3178 #endif
whismanoid 0:3edb3708c8c5 3179 #if HAS_pwmDriver12
whismanoid 0:3edb3708c8c5 3180 case 'c': case 0x0c: return true;
whismanoid 0:3edb3708c8c5 3181 #endif
whismanoid 0:3edb3708c8c5 3182 #if HAS_pwmDriver13
whismanoid 0:3edb3708c8c5 3183 case 'd': case 0x0d: return true;
whismanoid 0:3edb3708c8c5 3184 #endif
whismanoid 0:3edb3708c8c5 3185 #if HAS_pwmDriver14
whismanoid 0:3edb3708c8c5 3186 case 'e': case 0x0e: return true;
whismanoid 0:3edb3708c8c5 3187 #endif
whismanoid 0:3edb3708c8c5 3188 #if HAS_pwmDriver15
whismanoid 0:3edb3708c8c5 3189 case 'f': case 0x0f: return true;
whismanoid 0:3edb3708c8c5 3190 #endif
whismanoid 0:3edb3708c8c5 3191 default:
whismanoid 0:3edb3708c8c5 3192 return false;
whismanoid 0:3edb3708c8c5 3193 }
whismanoid 0:3edb3708c8c5 3194 }
whismanoid 0:3edb3708c8c5 3195 #endif
whismanoid 0:3edb3708c8c5 3196
whismanoid 0:3edb3708c8c5 3197 #if HAS_I2C // SUPPORT_I2C
whismanoid 0:3edb3708c8c5 3198 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 3199 // Search I2C device address list
whismanoid 0:3edb3708c8c5 3200 //
whismanoid 0:3edb3708c8c5 3201 // @param[in] deviceAddress7First = I2C device address (slave address on I2C bus), 7-bits, RIGHT-justified.
whismanoid 0:3edb3708c8c5 3202 // @param[in] deviceAddress7Last = I2C device address (slave address on I2C bus), 7-bits, RIGHT-justified.
whismanoid 0:3edb3708c8c5 3203 // @param[in] numDevicesFoundLimit = maximum number of devices to detect before halting search; in case SCL stuck low or pullups missing.
whismanoid 0:3edb3708c8c5 3204 // @returns deviceAddress on success; 0 on failure
whismanoid 0:3edb3708c8c5 3205 // @post g_I2C_deviceAddress7 is updated with any device that did ACK
whismanoid 0:3edb3708c8c5 3206 //
whismanoid 0:3edb3708c8c5 3207 void HuntAttachedI2CDevices(CmdLine& cmdLine, uint8_t deviceAddress7First, uint8_t deviceAddress7Last,
whismanoid 0:3edb3708c8c5 3208 const uint8_t numDevicesFoundLimit = 20)
whismanoid 0:3edb3708c8c5 3209 {
whismanoid 0:3edb3708c8c5 3210 // declare in narrower scope: MAX32625MBED I2C i2cMaster(...)
whismanoid 0:3edb3708c8c5 3211 I2C i2cMaster(I2C0_SDA, I2C0_SCL); // sda scl TARGET_MAX32635MBED: P1_6, P1_7 Arduino 10-pin header
whismanoid 0:3edb3708c8c5 3212 i2cMaster.frequency(g_I2C_SCL_Hz);
whismanoid 0:3edb3708c8c5 3213
whismanoid 0:3edb3708c8c5 3214 // %IP -- I2C probe
whismanoid 0:3edb3708c8c5 3215 // TODO: i2c transfer
whismanoid 0:3edb3708c8c5 3216 //const int addr7bit = 0x48; // 7 bit I2C address
whismanoid 0:3edb3708c8c5 3217 //const int addr8bit = 0x48 << 1; // 8bit I2C address, 0x90
whismanoid 0:3edb3708c8c5 3218 // /* int */ i2cMaster.read (int addr8bit, char *data, int length, bool repeated=false) // Read from an I2C slave.
whismanoid 0:3edb3708c8c5 3219 // /* int */ i2cMaster.read (int ack) // Read a single byte from the I2C bus.
whismanoid 0:3edb3708c8c5 3220 // /* int */ i2cMaster.write (int addr8bit, const char *data, int length, bool repeated=false) // Write to an I2C slave.
whismanoid 0:3edb3708c8c5 3221 // /* int */ i2cMaster.write (int data) // Write single byte out on the I2C bus.
whismanoid 0:3edb3708c8c5 3222 // /* void */ i2cMaster.start (void) // Creates a start condition on the I2C bus.
whismanoid 0:3edb3708c8c5 3223 // /* void */ i2cMaster.stop (void) // Creates a stop condition on the I2C bus.
whismanoid 0:3edb3708c8c5 3224 // /* int */ i2cMaster.transfer (int addr8bit, const char *tx_buffer, int tx_length, char *rx_buffer, int rx_length, const event_callback_t &callback, int event=I2C_EVENT_TRANSFER_COMPLETE, bool repeated=false) // Start nonblocking I2C transfer. More...
whismanoid 0:3edb3708c8c5 3225 // /* void */ i2cMaster.abort_transfer () // Abort the ongoing I2C transfer. More...
whismanoid 0:3edb3708c8c5 3226
whismanoid 0:3edb3708c8c5 3227 //const char probeWriteData[] = { 0x00 };
whismanoid 0:3edb3708c8c5 3228 //int probeWriteDataLength = 1;
whismanoid 0:3edb3708c8c5 3229 //bool isRepeatedStart = false;
whismanoid 0:3edb3708c8c5 3230 cmdLine.serial().printf("I2C Probe {0x%2.2X (0x%2.2X >> 1) to 0x%2.2X (0x%2.2X >> 1)}, limit %d\r\n",
whismanoid 0:3edb3708c8c5 3231 deviceAddress7First,
whismanoid 0:3edb3708c8c5 3232 deviceAddress7First << 1,
whismanoid 0:3edb3708c8c5 3233 deviceAddress7Last,
whismanoid 0:3edb3708c8c5 3234 deviceAddress7Last << 1,
whismanoid 0:3edb3708c8c5 3235 numDevicesFoundLimit); // HuntAttachedI2CDevices
whismanoid 0:3edb3708c8c5 3236 //~ const int i2cFileDescriptor = i2c_open_adapter(1);
whismanoid 0:3edb3708c8c5 3237 uint8_t numDevicesFound = 0;
whismanoid 0:3edb3708c8c5 3238 uint8_t last_valid_deviceAddress7 = 0;
whismanoid 0:3edb3708c8c5 3239 for (uint8_t deviceAddress7 = deviceAddress7First; deviceAddress7 <= deviceAddress7Last; deviceAddress7++)
whismanoid 0:3edb3708c8c5 3240 {
whismanoid 0:3edb3708c8c5 3241 //cmdLine.serial().printf(" (0x%2.2X >> 1) ", (deviceAddress7 << 1));
whismanoid 0:3edb3708c8c5 3242 //if (i2c_ioctl_I2C_SLAVE_i2cDeviceAddress7bits(i2cFileDescriptor, deviceAddress7) == 0)
whismanoid 0:3edb3708c8c5 3243 int addr8bit = deviceAddress7 * 2;
whismanoid 0:3edb3708c8c5 3244 //
whismanoid 0:3edb3708c8c5 3245 // /* int */ i2cMaster.write (int addr8bit, const char *data, int length, bool repeated=false) // Write to an I2C slave.
whismanoid 0:3edb3708c8c5 3246 // Returns 0 on success (ack), nonzero on failure (nack)
whismanoid 0:3edb3708c8c5 3247 //bool gotACK = (i2cMaster.write (addr8bit, probeWriteData, probeWriteDataLength, isRepeatedStart) == 0);
whismanoid 0:3edb3708c8c5 3248 //
whismanoid 0:3edb3708c8c5 3249 // SMBusQuick test
whismanoid 0:3edb3708c8c5 3250 i2cMaster.start();
whismanoid 0:3edb3708c8c5 3251 // /** Write single byte out on the I2C bus
whismanoid 0:3edb3708c8c5 3252 // *
whismanoid 0:3edb3708c8c5 3253 // * @param data data to write out on bus
whismanoid 0:3edb3708c8c5 3254 // *
whismanoid 0:3edb3708c8c5 3255 // * @returns
whismanoid 0:3edb3708c8c5 3256 // * '0' - NAK was received
whismanoid 0:3edb3708c8c5 3257 // * '1' - ACK was received,
whismanoid 0:3edb3708c8c5 3258 // * '2' - timeout
whismanoid 0:3edb3708c8c5 3259 // */
whismanoid 0:3edb3708c8c5 3260 // int write(int data);
whismanoid 0:3edb3708c8c5 3261 int writeStatus = i2cMaster.write(addr8bit);
whismanoid 0:3edb3708c8c5 3262 i2cMaster.stop();
whismanoid 0:3edb3708c8c5 3263 bool gotACK = (writeStatus == 1); // ACK was received
whismanoid 0:3edb3708c8c5 3264 if (writeStatus == 2) // timeout
whismanoid 0:3edb3708c8c5 3265 {
whismanoid 0:3edb3708c8c5 3266 cmdLine.serial().printf("- timeout\r\n");
whismanoid 0:3edb3708c8c5 3267 }
whismanoid 0:3edb3708c8c5 3268 //
whismanoid 0:3edb3708c8c5 3269 if (gotACK)
whismanoid 0:3edb3708c8c5 3270 {
whismanoid 0:3edb3708c8c5 3271 // @return status; error if (fileDescriptor < 0)
whismanoid 0:3edb3708c8c5 3272 cmdLine.serial().printf("+ ADDR=0x%2.2X (0x%2.2X >> 1) ACK\r\n", deviceAddress7, (deviceAddress7 << 1));
whismanoid 0:3edb3708c8c5 3273 numDevicesFound++;
whismanoid 0:3edb3708c8c5 3274 last_valid_deviceAddress7 = deviceAddress7;
whismanoid 0:3edb3708c8c5 3275 if (numDevicesFound > numDevicesFoundLimit)
whismanoid 0:3edb3708c8c5 3276 {
whismanoid 0:3edb3708c8c5 3277 break;
whismanoid 0:3edb3708c8c5 3278 }
whismanoid 0:3edb3708c8c5 3279 continue;
whismanoid 0:3edb3708c8c5 3280 }
whismanoid 0:3edb3708c8c5 3281 }
whismanoid 0:3edb3708c8c5 3282 if (numDevicesFound == 0)
whismanoid 0:3edb3708c8c5 3283 {
whismanoid 0:3edb3708c8c5 3284 cmdLine.serial().printf("- No I2C devices found. Maybe SCL/SDA are swapped?\r\n");
whismanoid 0:3edb3708c8c5 3285 }
whismanoid 0:3edb3708c8c5 3286 else if (numDevicesFound > numDevicesFoundLimit)
whismanoid 0:3edb3708c8c5 3287 {
whismanoid 0:3edb3708c8c5 3288 cmdLine.serial().printf("- Many I2C devices found. SCL/SDA missing pullup resistors? SCL stuck low?\r\n");
whismanoid 0:3edb3708c8c5 3289 }
whismanoid 0:3edb3708c8c5 3290 else
whismanoid 0:3edb3708c8c5 3291 {
whismanoid 0:3edb3708c8c5 3292 //~ i2c_ioctl_I2C_SLAVE_i2cDeviceAddress7bits(i2cFileDescriptor, last_valid_deviceAddress7);
whismanoid 0:3edb3708c8c5 3293 g_I2C_deviceAddress7 = last_valid_deviceAddress7;
whismanoid 0:3edb3708c8c5 3294 }
whismanoid 0:3edb3708c8c5 3295 //~ i2c_close(i2cFileDescriptor);
whismanoid 0:3edb3708c8c5 3296 }
whismanoid 0:3edb3708c8c5 3297 #endif // SUPPORT_I2C
whismanoid 0:3edb3708c8c5 3298
whismanoid 0:3edb3708c8c5 3299 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 3300 // periodic interrupt timer onTimerTick handler triggered by Ticker
whismanoid 0:3edb3708c8c5 3301 // analogIn0 (MAX32630:AIN_4 = AIN0 / 5.0) controls angular speed
whismanoid 0:3edb3708c8c5 3302 // analogIn1 (MAX32630:AIN_5 = AIN1 / 5.0) controls PWM duty cycle
whismanoid 0:3edb3708c8c5 3303 // note: measured 500ns overhead for MAX32630FTHR digitalInOut1.write(0); digitalInOut1.write(1);
whismanoid 0:3edb3708c8c5 3304 #if USE_PERIODIC_TIMER
whismanoid 0:3edb3708c8c5 3305 void onTimerTick() {
whismanoid 0:3edb3708c8c5 3306 } // onTimerTick
whismanoid 0:3edb3708c8c5 3307 #endif
whismanoid 0:3edb3708c8c5 3308
whismanoid 0:3edb3708c8c5 3309 #if USE_PERIODIC_TIMER
whismanoid 0:3edb3708c8c5 3310 // periodic interrupt timer command handlers -- enable timer
whismanoid 0:3edb3708c8c5 3311 void cmd_TE()
whismanoid 0:3edb3708c8c5 3312 {
whismanoid 0:3edb3708c8c5 3313 //us_timestamp_t interval_usec = 100000; // 100ms
whismanoid 0:3edb3708c8c5 3314 periodicInterruptTimer_interval_usec = 100000; // 100ms
whismanoid 0:3edb3708c8c5 3315 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 3316 DAPLINKserial.printf(" Timer Enable %d us\r\n", periodicInterruptTimer_interval_usec);
whismanoid 0:3edb3708c8c5 3317 # endif
whismanoid 0:3edb3708c8c5 3318 microUSBserial.printf(" Timer Enable %d us", periodicInterruptTimer_interval_usec);
whismanoid 0:3edb3708c8c5 3319 periodicInterruptTimer.attach_us(&onTimerTick, periodicInterruptTimer_interval_usec);
whismanoid 0:3edb3708c8c5 3320 // -- periodicInterruptTimer.attach(&onTimerTick, interval_sec); // the address of the function to be attached (onTimerTick) and the interval (2 seconds)
whismanoid 0:3edb3708c8c5 3321 // -- periodicInterruptTimer.attach_us(&onTimerTick, interval_usec); // the address of the function to be attached (onTimerTick) and the interval (2 seconds)
whismanoid 0:3edb3708c8c5 3322 // -- periodicInterruptTimer.attach(Callback<void()> func, float t);
whismanoid 0:3edb3708c8c5 3323 // -- periodicInterruptTimer.attach_us(Callback<void()> func, us_timestamp_t t);
whismanoid 0:3edb3708c8c5 3324 // TODO1: cmd_T add cSubCommand to change interval of Ticker periodic interrupt timer
whismanoid 0:3edb3708c8c5 3325 }
whismanoid 0:3edb3708c8c5 3326 #endif
whismanoid 0:3edb3708c8c5 3327
whismanoid 0:3edb3708c8c5 3328 #if USE_PERIODIC_TIMER
whismanoid 0:3edb3708c8c5 3329 // periodic interrupt timer command handlers -- disable timer
whismanoid 0:3edb3708c8c5 3330 void cmd_TD()
whismanoid 0:3edb3708c8c5 3331 {
whismanoid 0:3edb3708c8c5 3332 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 3333 DAPLINKserial.printf(" Timer Disable\r\n");
whismanoid 0:3edb3708c8c5 3334 # endif
whismanoid 0:3edb3708c8c5 3335 microUSBserial.printf(" Timer Disable ");
whismanoid 0:3edb3708c8c5 3336 periodicInterruptTimer.detach(); // Detach the function
whismanoid 0:3edb3708c8c5 3337 }
whismanoid 0:3edb3708c8c5 3338 #endif
whismanoid 0:3edb3708c8c5 3339
whismanoid 0:3edb3708c8c5 3340 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 3341 // When user presses button BUTTON1, perform a demo configuration
whismanoid 0:3edb3708c8c5 3342 #if HAS_BUTTON1_DEMO_INTERRUPT
whismanoid 0:3edb3708c8c5 3343 void onButton1FallingEdge(void)
whismanoid 0:3edb3708c8c5 3344 {
whismanoid 0:3edb3708c8c5 3345 void SelfTest(CmdLine & cmdLine);
whismanoid 0:3edb3708c8c5 3346
whismanoid 0:3edb3708c8c5 3347 // TODO1: BUTTON1 demo configuration LED blink
whismanoid 0:3edb3708c8c5 3348 //~ rgb_led.red(); // diagnostic rbg led RED
whismanoid 0:3edb3708c8c5 3349 //~ rgb_led.green(); // diagnostic rbg led GREEN
whismanoid 0:3edb3708c8c5 3350 //~ rgb_led.blue(); // diagnostic rbg led BLUE
whismanoid 0:3edb3708c8c5 3351 //~ rgb_led.white(); // diagnostic rbg led RED+GREEN+BLUE=WHITE
whismanoid 0:3edb3708c8c5 3352 //~ rgb_led.cyan(); // diagnostic rbg led GREEN+BLUE=CYAN
whismanoid 0:3edb3708c8c5 3353 //~ rgb_led.magenta(); // diagnostic rbg led RED+BLUE=MAGENTA
whismanoid 0:3edb3708c8c5 3354 //~ rgb_led.yellow(); // diagnostic rbg led RED+GREEN=YELLOW
whismanoid 0:3edb3708c8c5 3355 //~ rgb_led.black(); // diagnostic rbg led BLACK
whismanoid 0:3edb3708c8c5 3356 //~ led1 = LED_ON; led2 = LED_ON; led3 = LED_OFF; // diagnostic rbg led RED+GREEN=YELLOW
whismanoid 0:3edb3708c8c5 3357 //~ rgb_led.yellow(); // diagnostic rbg led RED+GREEN=YELLOW
whismanoid 0:3edb3708c8c5 3358 //~ ThisThread::sleep_for(250); // [since mbed-os-5.10] vs Thread::wait(250);
whismanoid 0:3edb3708c8c5 3359 //~ led1 = LED_OFF; led2 = LED_ON; led3 = LED_OFF; // diagnostic rbg led GREEN
whismanoid 0:3edb3708c8c5 3360 //~ rgb_led.black(); // diagnostic rbg led BLACK
whismanoid 0:3edb3708c8c5 3361 //~ ThisThread::sleep_for(250); // [since mbed-os-5.10] vs Thread::wait(250);
whismanoid 0:3edb3708c8c5 3362 //~ led1 = LED_ON; led2 = LED_ON; led3 = LED_OFF; // diagnostic rbg led RED+GREEN=YELLOW
whismanoid 0:3edb3708c8c5 3363 //~ rgb_led.yellow(); // diagnostic rbg led RED+GREEN=YELLOW
whismanoid 0:3edb3708c8c5 3364 //~ ThisThread::sleep_for(250); // [since mbed-os-5.10] vs Thread::wait(250);
whismanoid 0:3edb3708c8c5 3365 //~ led1 = LED_OFF; led2 = LED_ON; led3 = LED_OFF; // diagnostic rbg led GREEN
whismanoid 0:3edb3708c8c5 3366 //~ rgb_led.black(); // diagnostic rbg led BLACK
whismanoid 0:3edb3708c8c5 3367 //~ ThisThread::sleep_for(250); // [since mbed-os-5.10] vs Thread::wait(250);
whismanoid 0:3edb3708c8c5 3368 //~ rgb_led.yellow(); // diagnostic rbg led RED+GREEN=YELLOW
whismanoid 0:3edb3708c8c5 3369
whismanoid 0:3edb3708c8c5 3370 #if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 3371 SelfTest(cmdLine_microUSBserial);
whismanoid 0:3edb3708c8c5 3372 #elif HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 3373 SelfTest(cmdLine_DAPLINKserial);
whismanoid 0:3edb3708c8c5 3374 #endif
whismanoid 0:3edb3708c8c5 3375
whismanoid 0:3edb3708c8c5 3376 #if 0 // APPLICATION_MAX5715 // onButton1FallingEdge BUTTON1 demo configuration MAX5715BOB
whismanoid 0:3edb3708c8c5 3377 //~ cmdLine.serial().printf("MAX5715_REF(REF_AlwaysOn_2V500)");
whismanoid 0:3edb3708c8c5 3378 g_MAX5715_device.REF(MAX5715::REF_AlwaysOn_2V500);
whismanoid 0:3edb3708c8c5 3379
whismanoid 0:3edb3708c8c5 3380 uint16_t code = 4095;
whismanoid 0:3edb3708c8c5 3381 //~ cmdLine.serial().printf("CODEallLOADall code=%d", code);
whismanoid 0:3edb3708c8c5 3382 g_MAX5715_device.CODEallLOADall(code);
whismanoid 0:3edb3708c8c5 3383 #endif // APPLICATION_MAX5715
whismanoid 0:3edb3708c8c5 3384
whismanoid 0:3edb3708c8c5 3385 }
whismanoid 0:3edb3708c8c5 3386 #endif // HAS_BUTTON1_DEMO_INTERRUPT
whismanoid 0:3edb3708c8c5 3387
whismanoid 0:3edb3708c8c5 3388 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 3389 // When user presses button BUTTON2, perform a demo configuration
whismanoid 0:3edb3708c8c5 3390 #if HAS_BUTTON2_DEMO_INTERRUPT
whismanoid 0:3edb3708c8c5 3391 void onButton2FallingEdge(void)
whismanoid 0:3edb3708c8c5 3392 {
whismanoid 0:3edb3708c8c5 3393 // TODO1: BUTTON2 demo configuration LED blink
whismanoid 0:3edb3708c8c5 3394 //~ led1 = LED_ON; led2 = LED_ON; led3 = LED_OFF; // diagnostic rbg led RED+GREEN=YELLOW
whismanoid 0:3edb3708c8c5 3395 //~ rgb_led.yellow(); // diagnostic rbg led RED+GREEN=YELLOW
whismanoid 0:3edb3708c8c5 3396 // ThisThread::sleep_for(250); // [since mbed-os-5.10] vs Thread::wait(250);
whismanoid 0:3edb3708c8c5 3397 // led1 = LED_OFF; led2 = LED_ON; led3 = LED_OFF; // diagnostic rbg led GREEN
whismanoid 0:3edb3708c8c5 3398 //~ rgb_led.green(); // diagnostic rbg led GREEN
whismanoid 0:3edb3708c8c5 3399 // ThisThread::sleep_for(250); // [since mbed-os-5.10] vs Thread::wait(250);
whismanoid 0:3edb3708c8c5 3400 // led1 = LED_ON; led2 = LED_ON; led3 = LED_OFF; // diagnostic rbg led RED+GREEN=YELLOW
whismanoid 0:3edb3708c8c5 3401 //~ rgb_led.yellow(); // diagnostic rbg led RED+GREEN=YELLOW
whismanoid 0:3edb3708c8c5 3402 // ThisThread::sleep_for(250); // [since mbed-os-5.10] vs Thread::wait(250);
whismanoid 0:3edb3708c8c5 3403 // led1 = LED_OFF; led2 = LED_ON; led3 = LED_OFF; // diagnostic rbg led GREEN
whismanoid 0:3edb3708c8c5 3404 //~ rgb_led.green(); // diagnostic rbg led GREEN
whismanoid 0:3edb3708c8c5 3405 // ThisThread::sleep_for(250); // [since mbed-os-5.10] vs Thread::wait(250);
whismanoid 0:3edb3708c8c5 3406
whismanoid 0:3edb3708c8c5 3407 #if APPLICATION_MAX5715 // onButton2FallingEdge BUTTON2 demo configuration MAX5715BOB
whismanoid 0:3edb3708c8c5 3408 //~ cmdLine.serial().printf("MAX5715_REF(REF_AlwaysOn_2V048)");
whismanoid 0:3edb3708c8c5 3409 g_MAX5715_device.REF(MAX5715::REF_AlwaysOn_2V048);
whismanoid 0:3edb3708c8c5 3410 //
whismanoid 0:3edb3708c8c5 3411 uint16_t ch = 0;
whismanoid 0:3edb3708c8c5 3412 uint16_t code = 0xccc;
whismanoid 0:3edb3708c8c5 3413 //~ cmdLine.serial().printf("CODEnLOADn ch=%d code=%d", ch, code);
whismanoid 0:3edb3708c8c5 3414 g_MAX5715_device.CODEnLOADn(ch, code);
whismanoid 0:3edb3708c8c5 3415 //
whismanoid 0:3edb3708c8c5 3416 ch = 1;
whismanoid 0:3edb3708c8c5 3417 code = 0x800;
whismanoid 0:3edb3708c8c5 3418 //~ cmdLine.serial().printf("CODEnLOADn ch=%d code=%d", ch, code);
whismanoid 0:3edb3708c8c5 3419 g_MAX5715_device.CODEnLOADn(ch, code);
whismanoid 0:3edb3708c8c5 3420 //
whismanoid 0:3edb3708c8c5 3421 ch = 2;
whismanoid 0:3edb3708c8c5 3422 code = 0x666;
whismanoid 0:3edb3708c8c5 3423 //~ cmdLine.serial().printf("CODEnLOADn ch=%d code=%d", ch, code);
whismanoid 0:3edb3708c8c5 3424 g_MAX5715_device.CODEnLOADn(ch, code);
whismanoid 0:3edb3708c8c5 3425 //
whismanoid 0:3edb3708c8c5 3426 ch = 3;
whismanoid 0:3edb3708c8c5 3427 code = 0xFFF;
whismanoid 0:3edb3708c8c5 3428 //~ cmdLine.serial().printf("CODEnLOADn ch=%d code=%d", ch, code);
whismanoid 0:3edb3708c8c5 3429 g_MAX5715_device.CODEnLOADn(ch, code);
whismanoid 0:3edb3708c8c5 3430 #elif APPLICATION_MAX11131 // onButton2FallingEdge BUTTON2 demo configuration MAX11131BOB
whismanoid 0:3edb3708c8c5 3431 // TODO1: demo
whismanoid 0:3edb3708c8c5 3432 // MAX11131 > 4
whismanoid 0:3edb3708c8c5 3433 // ScanStandardExternalClock ch=9 pm=0 id=1
whismanoid 0:3edb3708c8c5 3434 // ScanRead_nWords_chanID nWords=10
whismanoid 0:3edb3708c8c5 3435 // ch=0 xu=2964 = 0x0b94 = 1.8091V
whismanoid 0:3edb3708c8c5 3436 // ch=1 xu=2227 = 0x08b3 = 1.3593V
whismanoid 0:3edb3708c8c5 3437 // ch=2 xu=1570 = 0x0622 = 0.9583V
whismanoid 0:3edb3708c8c5 3438 // ch=3 xu=865 = 0x0361 = 0.5280V
whismanoid 0:3edb3708c8c5 3439 // ch=4 xu=630 = 0x0276 = 0.3845V
whismanoid 0:3edb3708c8c5 3440 // ch=5 xu=594 = 0x0252 = 0.3625V
whismanoid 0:3edb3708c8c5 3441 // ch=6 xu=461 = 0x01cd = 0.2814V
whismanoid 0:3edb3708c8c5 3442 // ch=7 xu=364 = 0x016c = 0.2222V
whismanoid 0:3edb3708c8c5 3443 // ch=8 xu=480 = 0x01e0 = 0.2930V
whismanoid 0:3edb3708c8c5 3444 // ch=9 xu=616 = 0x0268 = 0.3760V
whismanoid 0:3edb3708c8c5 3445 g_MAX11131_device.channelNumber_0_15 = 9;
whismanoid 0:3edb3708c8c5 3446 g_MAX11131_device.PowerManagement_0_2 = 0;
whismanoid 0:3edb3708c8c5 3447 g_MAX11131_device.chan_id_0_1 = 1;
whismanoid 0:3edb3708c8c5 3448 g_MAX11131_device.NumWords = g_MAX11131_device.ScanStandardExternalClock();
whismanoid 0:3edb3708c8c5 3449 //
whismanoid 0:3edb3708c8c5 3450 // Read raw ADC codes from device into AINcode[] and RAW_misoData16[]
whismanoid 0:3edb3708c8c5 3451 // @pre one of the MAX11311_Scan functions was called, setting g_MAX11131_device.NumWords
whismanoid 0:3edb3708c8c5 3452 g_MAX11131_device.ReadAINcode();
whismanoid 0:3edb3708c8c5 3453 // @post RAW_misoData16[index] contains the raw SPI Master-In,Slave-Out data
whismanoid 0:3edb3708c8c5 3454 // @post AINcode[NUM_CHANNELS] contains the latest readings in LSBs
whismanoid 0:3edb3708c8c5 3455 //
whismanoid 0:3edb3708c8c5 3456 // TODO: compare with mbed/Arduino AIN0-AIN3
whismanoid 0:3edb3708c8c5 3457 //
whismanoid 0:3edb3708c8c5 3458 #elif APPLICATION_MAX5171 // onButton2FallingEdge BUTTON2 demo configuration MAX5171BOB
whismanoid 0:3edb3708c8c5 3459 // TODO: demo
whismanoid 0:3edb3708c8c5 3460 uint16_t code = 0xccc;
whismanoid 0:3edb3708c8c5 3461 g_MAX5171_device.CODE(code);
whismanoid 0:3edb3708c8c5 3462 #elif APPLICATION_MAX11410 // onButton2FallingEdge BUTTON2 demo configuration MAX11410BOB
whismanoid 0:3edb3708c8c5 3463 // TODO: demo
whismanoid 0:3edb3708c8c5 3464 g_MAX11410_device.CODEnLOADn(ch, code);
whismanoid 0:3edb3708c8c5 3465 #elif APPLICATION_MAX12345 // onButton2FallingEdge BUTTON2 demo configuration MAX12345BOB
whismanoid 0:3edb3708c8c5 3466 // TODO: demo
whismanoid 0:3edb3708c8c5 3467 g_MAX12345_device.CODEnLOADn(ch, code);
whismanoid 0:3edb3708c8c5 3468 #endif // APPLICATION_MAX5715
whismanoid 0:3edb3708c8c5 3469 rgb_led.blue(); // diagnostic rbg led BLUE
whismanoid 0:3edb3708c8c5 3470
whismanoid 0:3edb3708c8c5 3471 }
whismanoid 0:3edb3708c8c5 3472 #endif // HAS_BUTTON2_DEMO_INTERRUPT
whismanoid 0:3edb3708c8c5 3473
whismanoid 0:3edb3708c8c5 3474 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 3475 // TODO1: use MaximTinyTester encapsulate SelfTest support functions
whismanoid 0:3edb3708c8c5 3476 //--------------------------------------------------
whismanoid 2:b3a8a0ca0a94 3477 #if APPLICATION_MAX5715 // SelfTest
whismanoid 2:b3a8a0ca0a94 3478 //
whismanoid 2:b3a8a0ca0a94 3479 // Note: ide.mbed.com does not support C++11 Lambda Expressions
whismanoid 2:b3a8a0ca0a94 3480 // -- see https://os.mbed.com/questions/82580/Is-there-solution-for-defining-of-interr/
whismanoid 2:b3a8a0ca0a94 3481 //
whismanoid 2:b3a8a0ca0a94 3482 // define function under test using C++11 lambda expression [](){}
whismanoid 2:b3a8a0ca0a94 3483 // uint8_t MAX5715::Init(void)
whismanoid 2:b3a8a0ca0a94 3484 // uint8_t (*fn_MAX5715_Init)() = [](){ return g_MAX5715_device.Init(); };
whismanoid 2:b3a8a0ca0a94 3485 uint8_t fn_MAX5715_Init() { return g_MAX5715_device.Init(); };
whismanoid 2:b3a8a0ca0a94 3486 //
whismanoid 2:b3a8a0ca0a94 3487 // define function under test using C++11 lambda expression [](){}
whismanoid 2:b3a8a0ca0a94 3488 // uint16_t MAX5715::DACCodeOfVoltage(double voltageV)
whismanoid 2:b3a8a0ca0a94 3489 // uint16_t (*fn_MAX5715_DACCodeOfVoltage)(double) = [](double voltageV){ return g_MAX5715_device.DACCodeOfVoltage(voltageV); };
whismanoid 2:b3a8a0ca0a94 3490 uint16_t fn_MAX5715_DACCodeOfVoltage(double voltageV) { return g_MAX5715_device.DACCodeOfVoltage(voltageV); };
whismanoid 2:b3a8a0ca0a94 3491 //
whismanoid 2:b3a8a0ca0a94 3492 // define function under test using C++11 lambda expression [](){}
whismanoid 2:b3a8a0ca0a94 3493 // double MAX5715::VoltageOfCode(uint16_t value_u14)
whismanoid 2:b3a8a0ca0a94 3494 //double (*fn_MAX5715_VoltageOfCode)(uint16_t) = [](uint16_t value_u14){ return g_MAX5715_device.VoltageOfCode(value_u14); };
whismanoid 2:b3a8a0ca0a94 3495 double fn_MAX5715_VoltageOfCode(uint16_t value_u14) { return g_MAX5715_device.VoltageOfCode(value_u14); };
whismanoid 2:b3a8a0ca0a94 3496 //
whismanoid 2:b3a8a0ca0a94 3497 // define function under test using C++11 lambda expression [](){}
whismanoid 2:b3a8a0ca0a94 3498 // void MAX5715::CODEnLOADn(uint8_t channel_0_3, uint16_t dacCodeLsbs)
whismanoid 2:b3a8a0ca0a94 3499 // void (*fn_MAX5715_CODEnLOADn)(uint8_t channel_0_3, uint16_t dacCodeLsbs) = [](uint8_t channel_0_3, uint16_t dacCodeLsbs){ return g_MAX5715_device.CODEnLOADn(channel_0_3, dacCodeLsbs); };
whismanoid 2:b3a8a0ca0a94 3500 void fn_MAX5715_CODEnLOADn (uint8_t channel_0_3, uint16_t dacCodeLsbs) { return g_MAX5715_device.CODEnLOADn(channel_0_3, dacCodeLsbs); };
whismanoid 2:b3a8a0ca0a94 3501 //
whismanoid 2:b3a8a0ca0a94 3502 #endif // APPLICATION_MAX5715 // SelfTest
whismanoid 2:b3a8a0ca0a94 3503 //--------------------------------------------------
whismanoid 2:b3a8a0ca0a94 3504 #if APPLICATION_MAX11131 // SelfTest
whismanoid 2:b3a8a0ca0a94 3505 //
whismanoid 2:b3a8a0ca0a94 3506 // Note: ide.mbed.com does not support C++11 Lambda Expressions
whismanoid 2:b3a8a0ca0a94 3507 // -- see https://os.mbed.com/questions/82580/Is-there-solution-for-defining-of-interr/
whismanoid 2:b3a8a0ca0a94 3508 //
whismanoid 2:b3a8a0ca0a94 3509 // define function under test using C++11 lambda expression [](){}
whismanoid 2:b3a8a0ca0a94 3510 //
whismanoid 2:b3a8a0ca0a94 3511 #endif // APPLICATION_MAX11131 // SelfTest
whismanoid 2:b3a8a0ca0a94 3512 //--------------------------------------------------
whismanoid 2:b3a8a0ca0a94 3513 #if APPLICATION_MAX5171 // SelfTest
whismanoid 2:b3a8a0ca0a94 3514 //
whismanoid 2:b3a8a0ca0a94 3515 // Note: ide.mbed.com does not support C++11 Lambda Expressions
whismanoid 2:b3a8a0ca0a94 3516 // -- see https://os.mbed.com/questions/82580/Is-there-solution-for-defining-of-interr/
whismanoid 2:b3a8a0ca0a94 3517 //
whismanoid 2:b3a8a0ca0a94 3518 // define function under test using C++11 lambda expression [](){}
whismanoid 2:b3a8a0ca0a94 3519 // uint8_t MAX5171::Init(void)
whismanoid 2:b3a8a0ca0a94 3520 // uint8_t (*fn_MAX5171_Init)() = [](){ return g_MAX5171_device.Init(); };
whismanoid 2:b3a8a0ca0a94 3521 uint8_t fn_MAX5171_Init() { return g_MAX5171_device.Init(); };
whismanoid 2:b3a8a0ca0a94 3522 //
whismanoid 2:b3a8a0ca0a94 3523 // define function under test using C++11 lambda expression [](){}
whismanoid 2:b3a8a0ca0a94 3524 // uint16_t MAX5171::DACCodeOfVoltage(double voltageV)
whismanoid 2:b3a8a0ca0a94 3525 // uint16_t (*fn_MAX5171_DACCodeOfVoltage)(double) = [](double voltageV){ return g_MAX5171_device.DACCodeOfVoltage(voltageV); };
whismanoid 2:b3a8a0ca0a94 3526 uint16_t fn_MAX5171_DACCodeOfVoltage(double voltageV) { return g_MAX5171_device.DACCodeOfVoltage(voltageV); };
whismanoid 2:b3a8a0ca0a94 3527 //
whismanoid 2:b3a8a0ca0a94 3528 // define function under test using C++11 lambda expression [](){}
whismanoid 2:b3a8a0ca0a94 3529 // double MAX5171::VoltageOfCode(uint16_t value_u14)
whismanoid 2:b3a8a0ca0a94 3530 // double (*fn_MAX5171_VoltageOfCode)(uint16_t) = [](uint16_t value_u14){ return g_MAX5171_device.VoltageOfCode(value_u14); };
whismanoid 2:b3a8a0ca0a94 3531 double fn_MAX5171_VoltageOfCode(uint16_t value_u14) { return g_MAX5171_device.VoltageOfCode(value_u14); };
whismanoid 2:b3a8a0ca0a94 3532 //
whismanoid 2:b3a8a0ca0a94 3533 // define function under test using C++11 lambda expression [](){}
whismanoid 2:b3a8a0ca0a94 3534 // uint8_t MAX5171::CODE_LOAD(uint16_t dacCodeLsbs)
whismanoid 2:b3a8a0ca0a94 3535 // uint8_t (*fn_MAX5171_CODE_LOAD)(uint16_t dacCodeLsbs) = [](uint16_t dacCodeLsbs){ return g_MAX5171_device.CODE_LOAD(dacCodeLsbs); };
whismanoid 2:b3a8a0ca0a94 3536 uint8_t fn_MAX5171_CODE_LOAD(uint16_t dacCodeLsbs) { return g_MAX5171_device.CODE_LOAD(dacCodeLsbs); };
whismanoid 2:b3a8a0ca0a94 3537 //
whismanoid 2:b3a8a0ca0a94 3538 //
whismanoid 2:b3a8a0ca0a94 3539 #endif // APPLICATION_MAX5171 // SelfTest
whismanoid 2:b3a8a0ca0a94 3540 //--------------------------------------------------
whismanoid 2:b3a8a0ca0a94 3541 #if APPLICATION_MAX11410 // SelfTest
whismanoid 2:b3a8a0ca0a94 3542 //
whismanoid 2:b3a8a0ca0a94 3543 // Note: ide.mbed.com does not support C++11 Lambda Expressions
whismanoid 2:b3a8a0ca0a94 3544 // -- see https://os.mbed.com/questions/82580/Is-there-solution-for-defining-of-interr/
whismanoid 2:b3a8a0ca0a94 3545 //
whismanoid 2:b3a8a0ca0a94 3546 // define function under test using C++11 lambda expression [](){}
whismanoid 2:b3a8a0ca0a94 3547 //
whismanoid 2:b3a8a0ca0a94 3548 #endif // APPLICATION_MAX11410 // SelfTest
whismanoid 2:b3a8a0ca0a94 3549 //--------------------------------------------------
whismanoid 2:b3a8a0ca0a94 3550 #if APPLICATION_MAX12345 // SelfTest
whismanoid 2:b3a8a0ca0a94 3551 //
whismanoid 2:b3a8a0ca0a94 3552 // Note: ide.mbed.com does not support C++11 Lambda Expressions
whismanoid 2:b3a8a0ca0a94 3553 // -- see https://os.mbed.com/questions/82580/Is-there-solution-for-defining-of-interr/
whismanoid 2:b3a8a0ca0a94 3554 //
whismanoid 2:b3a8a0ca0a94 3555 // define function under test using C++11 lambda expression [](){}
whismanoid 2:b3a8a0ca0a94 3556 //
whismanoid 2:b3a8a0ca0a94 3557 #endif // APPLICATION_MAX12345 // SelfTest
whismanoid 2:b3a8a0ca0a94 3558 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 3559 void SelfTest_print_DACCodeOfVoltage(CmdLine& cmdLine, double voltageV)
whismanoid 0:3edb3708c8c5 3560 {
whismanoid 0:3edb3708c8c5 3561 cmdLine.serial().printf("DACCodeOfVoltage(%6.4fV)", voltageV);
whismanoid 0:3edb3708c8c5 3562 // For 12-bit DAC, dtostrf width, precision = 6, 4 i.e. 0.0001
whismanoid 0:3edb3708c8c5 3563 // For 14-bit DAC, dtostrf width, precision = 7, 5 i.e. 0.00001
whismanoid 0:3edb3708c8c5 3564 //~ dtostrf(voltageV, 6, 4, strOutLineBuffer); // value, width, precision, char* buffer
whismanoid 0:3edb3708c8c5 3565 //~ cmdLine.serial().printf(strOutLineBuffer);
whismanoid 0:3edb3708c8c5 3566 //~ cmdLine.serial().printf("V)");
whismanoid 0:3edb3708c8c5 3567 }
whismanoid 0:3edb3708c8c5 3568 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 3569 #if APPLICATION_MAX5171 // SelfTest
whismanoid 0:3edb3708c8c5 3570 void SelfTest_print_VoltageOfCode(CmdLine& cmdLine, uint16_t value_u14)
whismanoid 0:3edb3708c8c5 3571 {
whismanoid 0:3edb3708c8c5 3572 cmdLine.serial().printf("VoltageOfCode(%d)", value_u14);
whismanoid 0:3edb3708c8c5 3573 }
whismanoid 0:3edb3708c8c5 3574 #endif // APPLICATION_MAX5171
whismanoid 0:3edb3708c8c5 3575 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 3576 #if APPLICATION_MAX5715 // SelfTest
whismanoid 0:3edb3708c8c5 3577 void SelfTest_print_Vref(CmdLine & cmdLine)
whismanoid 0:3edb3708c8c5 3578 {
whismanoid 0:3edb3708c8c5 3579 cmdLine.serial().printf("VRef = %6.4fV LSB=%6.4fV", g_MAX5715_device.VRef, (g_MAX5715_device.VRef / 4095));
whismanoid 0:3edb3708c8c5 3580 //~ dtostrf(g_MAX5715_device.VRef, 6, 4, strOutLineBuffer); // value, width, precision, char* buffer
whismanoid 0:3edb3708c8c5 3581 //~ cmdLine.serial().printf(strOutLineBuffer);
whismanoid 0:3edb3708c8c5 3582 //~ cmdLine.serial().printf("V LSB=");
whismanoid 0:3edb3708c8c5 3583 // For 12-bit DAC, dtostrf width, precision = 6, 4 i.e. 0.0001
whismanoid 0:3edb3708c8c5 3584 // For 14-bit DAC, dtostrf width, precision = 7, 5 i.e. 0.00001
whismanoid 0:3edb3708c8c5 3585 //~ dtostrf( (g_MAX5715_device.VRef / 4095), 6, 4, strOutLineBuffer); // value, width, precision, char* buffer
whismanoid 0:3edb3708c8c5 3586 //~ cmdLine.serial().printf(strOutLineBuffer);
whismanoid 0:3edb3708c8c5 3587 //~ cmdLine.serial().printf("V");
whismanoid 0:3edb3708c8c5 3588 }
whismanoid 0:3edb3708c8c5 3589 #endif // APPLICATION_MAX5715
whismanoid 0:3edb3708c8c5 3590 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 3591 #if APPLICATION_MAX5171 // SelfTest
whismanoid 0:3edb3708c8c5 3592 void SelfTest_print_Vref(CmdLine & cmdLine)
whismanoid 0:3edb3708c8c5 3593 {
whismanoid 0:3edb3708c8c5 3594 cmdLine.serial().printf("VRef = %7.5fV LSB=%7.5fV", g_MAX5171_device.VRef, (g_MAX5171_device.VRef / 16383));
whismanoid 0:3edb3708c8c5 3595 // For 12-bit DAC, dtostrf width, precision = 6, 4 i.e. 0.0001
whismanoid 0:3edb3708c8c5 3596 // For 14-bit DAC, dtostrf width, precision = 7, 5 i.e. 0.00001
whismanoid 0:3edb3708c8c5 3597 }
whismanoid 0:3edb3708c8c5 3598 #endif // APPLICATION_MAX5171
whismanoid 0:3edb3708c8c5 3599 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 3600 #if HAS_SPI2_MAX541
whismanoid 0:3edb3708c8c5 3601 MAX541 max541(spi2_max541, spi2_max541_cs);
whismanoid 0:3edb3708c8c5 3602 #endif
whismanoid 0:3edb3708c8c5 3603 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 3604 bool SelfTest_MAX541_Voltage(CmdLine & cmdLine, MAX541 &max541, double voltageV)
whismanoid 0:3edb3708c8c5 3605 {
whismanoid 0:3edb3708c8c5 3606 max541.Set_Voltage(voltageV);
whismanoid 0:3edb3708c8c5 3607 // cmdLine.serial().printf("\r\n Test Fixture: MAX541 set output to %1.3fV = code 0x%4.4x", max541.Get_Voltage(), max541.Get_Code());
whismanoid 0:3edb3708c8c5 3608 cmdLine.serial().printf("\r\n Test Fixture: MAX541 set output to 0x%4.4x = %1.3fV",
whismanoid 0:3edb3708c8c5 3609 max541.Get_Code(), max541.Get_Voltage());
whismanoid 0:3edb3708c8c5 3610 #if analogIn4_IS_HIGH_RANGE_OF_analogIn0
whismanoid 0:3edb3708c8c5 3611 // Platform board uses AIN4,AIN5,.. as high range of AIN0,AIN1,..
whismanoid 0:3edb3708c8c5 3612 MaximTinyTester tinyTester(cmdLine, analogIn4, analogIn5, analogIn2, analogIn3, analogIn0, analogIn4);
whismanoid 0:3edb3708c8c5 3613 tinyTester.analogInPin_fullScaleVoltage[0] = analogInPin_fullScaleVoltage[4]; // board support
whismanoid 0:3edb3708c8c5 3614 tinyTester.analogInPin_fullScaleVoltage[1] = analogInPin_fullScaleVoltage[5]; // board support
whismanoid 0:3edb3708c8c5 3615 tinyTester.analogInPin_fullScaleVoltage[2] = analogInPin_fullScaleVoltage[2]; // board support
whismanoid 0:3edb3708c8c5 3616 tinyTester.analogInPin_fullScaleVoltage[3] = analogInPin_fullScaleVoltage[3]; // board support
whismanoid 0:3edb3708c8c5 3617 tinyTester.analogInPin_fullScaleVoltage[4] = analogInPin_fullScaleVoltage[0]; // board support
whismanoid 0:3edb3708c8c5 3618 tinyTester.analogInPin_fullScaleVoltage[5] = analogInPin_fullScaleVoltage[1]; // board support
whismanoid 0:3edb3708c8c5 3619 // low range channels AIN0, AIN1, AIN2, AIN3
whismanoid 0:3edb3708c8c5 3620 #else // analogIn4_IS_HIGH_RANGE_OF_analogIn0
whismanoid 0:3edb3708c8c5 3621 // Platform board uses simple analog inputs
whismanoid 0:3edb3708c8c5 3622 MaximTinyTester tinyTester(cmdLine, analogIn0, analogIn1, analogIn2, analogIn3, analogIn4, analogIn5);
whismanoid 0:3edb3708c8c5 3623 tinyTester.analogInPin_fullScaleVoltage[0] = analogInPin_fullScaleVoltage[0]; // board support
whismanoid 0:3edb3708c8c5 3624 tinyTester.analogInPin_fullScaleVoltage[1] = analogInPin_fullScaleVoltage[1]; // board support
whismanoid 0:3edb3708c8c5 3625 tinyTester.analogInPin_fullScaleVoltage[2] = analogInPin_fullScaleVoltage[2]; // board support
whismanoid 0:3edb3708c8c5 3626 tinyTester.analogInPin_fullScaleVoltage[3] = analogInPin_fullScaleVoltage[3]; // board support
whismanoid 0:3edb3708c8c5 3627 tinyTester.analogInPin_fullScaleVoltage[4] = analogInPin_fullScaleVoltage[4]; // board support
whismanoid 0:3edb3708c8c5 3628 tinyTester.analogInPin_fullScaleVoltage[5] = analogInPin_fullScaleVoltage[5]; // board support
whismanoid 0:3edb3708c8c5 3629 #endif
whismanoid 5:82037e281451 3630 tinyTester.Wait_Output_Settling(); // wait for MAX541 to settle
whismanoid 0:3edb3708c8c5 3631 // TODO: tinyTester.AnalogIn0_Read_Expect_voltageV replaces SelfTest_AnalogInput_Expect_ch_V
whismanoid 0:3edb3708c8c5 3632 tinyTester.err_threshold = 0.100;
whismanoid 0:3edb3708c8c5 3633 return tinyTester.AnalogIn0_Read_Expect_voltageV(voltageV);
whismanoid 0:3edb3708c8c5 3634 }
whismanoid 0:3edb3708c8c5 3635 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 3636 void SelfTest(CmdLine & cmdLine)
whismanoid 0:3edb3708c8c5 3637 {
whismanoid 0:3edb3708c8c5 3638 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 3639 #if analogIn4_IS_HIGH_RANGE_OF_analogIn0
whismanoid 0:3edb3708c8c5 3640 // Platform board uses AIN4,AIN5,.. as high range of AIN0,AIN1,..
whismanoid 0:3edb3708c8c5 3641 // MaximTinyTester(Stream& AssociatedSerialPort, const char *Name);
whismanoid 0:3edb3708c8c5 3642 MaximTinyTester tinyTester(cmdLine, analogIn4, analogIn5, analogIn2, analogIn3, analogIn0, analogIn4);
whismanoid 0:3edb3708c8c5 3643 tinyTester.analogInPin_fullScaleVoltage[0] = analogInPin_fullScaleVoltage[4]; // board support
whismanoid 0:3edb3708c8c5 3644 tinyTester.analogInPin_fullScaleVoltage[1] = analogInPin_fullScaleVoltage[5]; // board support
whismanoid 0:3edb3708c8c5 3645 tinyTester.analogInPin_fullScaleVoltage[2] = analogInPin_fullScaleVoltage[2]; // board support
whismanoid 0:3edb3708c8c5 3646 tinyTester.analogInPin_fullScaleVoltage[3] = analogInPin_fullScaleVoltage[3]; // board support
whismanoid 0:3edb3708c8c5 3647 tinyTester.analogInPin_fullScaleVoltage[4] = analogInPin_fullScaleVoltage[0]; // board support
whismanoid 0:3edb3708c8c5 3648 tinyTester.analogInPin_fullScaleVoltage[5] = analogInPin_fullScaleVoltage[1]; // board support
whismanoid 0:3edb3708c8c5 3649 // low range channels AIN0, AIN1, AIN2, AIN3
whismanoid 0:3edb3708c8c5 3650 #else // analogIn4_IS_HIGH_RANGE_OF_analogIn0
whismanoid 0:3edb3708c8c5 3651 // Platform board uses simple analog inputs
whismanoid 0:3edb3708c8c5 3652 // MaximTinyTester(Stream& AssociatedSerialPort, const char *Name);
whismanoid 0:3edb3708c8c5 3653 MaximTinyTester tinyTester(cmdLine, analogIn0, analogIn1, analogIn2, analogIn3, analogIn4, analogIn5);
whismanoid 0:3edb3708c8c5 3654 tinyTester.analogInPin_fullScaleVoltage[0] = analogInPin_fullScaleVoltage[0]; // board support
whismanoid 0:3edb3708c8c5 3655 tinyTester.analogInPin_fullScaleVoltage[1] = analogInPin_fullScaleVoltage[1]; // board support
whismanoid 0:3edb3708c8c5 3656 tinyTester.analogInPin_fullScaleVoltage[2] = analogInPin_fullScaleVoltage[2]; // board support
whismanoid 0:3edb3708c8c5 3657 tinyTester.analogInPin_fullScaleVoltage[3] = analogInPin_fullScaleVoltage[3]; // board support
whismanoid 0:3edb3708c8c5 3658 tinyTester.analogInPin_fullScaleVoltage[4] = analogInPin_fullScaleVoltage[4]; // board support
whismanoid 0:3edb3708c8c5 3659 tinyTester.analogInPin_fullScaleVoltage[5] = analogInPin_fullScaleVoltage[5]; // board support
whismanoid 0:3edb3708c8c5 3660 #endif
whismanoid 0:3edb3708c8c5 3661 #if USE_LEDS
whismanoid 0:3edb3708c8c5 3662 //~ rgb_led.red(); // diagnostic rbg led RED
whismanoid 0:3edb3708c8c5 3663 //~ rgb_led.green(); // diagnostic rbg led GREEN
whismanoid 0:3edb3708c8c5 3664 //~ rgb_led.blue(); // diagnostic rbg led BLUE
whismanoid 0:3edb3708c8c5 3665 //~ rgb_led.white(); // diagnostic rbg led RED+GREEN+BLUE=WHITE
whismanoid 0:3edb3708c8c5 3666 //~ rgb_led.cyan(); // diagnostic rbg led GREEN+BLUE=CYAN
whismanoid 0:3edb3708c8c5 3667 //~ rgb_led.magenta(); // diagnostic rbg led RED+BLUE=MAGENTA
whismanoid 0:3edb3708c8c5 3668 rgb_led.yellow(); // diagnostic rbg led RED+GREEN=YELLOW
whismanoid 0:3edb3708c8c5 3669 //~ rgb_led.black(); // diagnostic rbg led BLACK
whismanoid 0:3edb3708c8c5 3670 #endif // USE_LEDS
whismanoid 0:3edb3708c8c5 3671 #if APPLICATION_MAX5715 // SelfTest
whismanoid 0:3edb3708c8c5 3672 //
whismanoid 5:82037e281451 3673 // tinyTester.FunctionCall_Expect replaces SelfTest_DACCodeOfVoltage_Expect
whismanoid 0:3edb3708c8c5 3674 //
whismanoid 1:40369075c365 3675 // Note: ide.mbed.com does not support C++11 Lambda Expressions
whismanoid 1:40369075c365 3676 // -- see https://os.mbed.com/questions/82580/Is-there-solution-for-defining-of-interr/
whismanoid 0:3edb3708c8c5 3677 // define function under test using C++11 lambda expression [](){}
whismanoid 0:3edb3708c8c5 3678 // uint8_t MAX5715::Init(void)
whismanoid 2:b3a8a0ca0a94 3679 //uint8_t (*fn_MAX5715_Init)() = [](){ return g_MAX5715_device.Init(); };
whismanoid 0:3edb3708c8c5 3680 //
whismanoid 0:3edb3708c8c5 3681 // define function under test using C++11 lambda expression [](){}
whismanoid 0:3edb3708c8c5 3682 // uint16_t MAX5715::DACCodeOfVoltage(double voltageV)
whismanoid 2:b3a8a0ca0a94 3683 //uint16_t (*fn_MAX5715_DACCodeOfVoltage)(double) = [](double voltageV){ return g_MAX5715_device.DACCodeOfVoltage(voltageV); };
whismanoid 0:3edb3708c8c5 3684 //
whismanoid 0:3edb3708c8c5 3685 // define function under test using C++11 lambda expression [](){}
whismanoid 0:3edb3708c8c5 3686 // double MAX5715::VoltageOfCode(uint16_t value_u14)
whismanoid 2:b3a8a0ca0a94 3687 //double (*fn_MAX5715_VoltageOfCode)(uint16_t) = [](uint16_t value_u14){ return g_MAX5715_device.VoltageOfCode(value_u14); };
whismanoid 0:3edb3708c8c5 3688 //
whismanoid 0:3edb3708c8c5 3689 // define function under test using C++11 lambda expression [](){}
whismanoid 0:3edb3708c8c5 3690 // void MAX5715::CODEnLOADn(uint8_t channel_0_3, uint16_t dacCodeLsbs)
whismanoid 2:b3a8a0ca0a94 3691 //void (*fn_MAX5715_CODEnLOADn)(uint8_t channel_0_3, uint16_t dacCodeLsbs) = [](uint8_t channel_0_3, uint16_t dacCodeLsbs){ return g_MAX5715_device.CODEnLOADn(channel_0_3, dacCodeLsbs); };
whismanoid 0:3edb3708c8c5 3692 //
whismanoid 0:3edb3708c8c5 3693 //
whismanoid 0:3edb3708c8c5 3694 //
whismanoid 0:3edb3708c8c5 3695 //
whismanoid 0:3edb3708c8c5 3696 //
whismanoid 0:3edb3708c8c5 3697 //------------------------------------------------------------
whismanoid 0:3edb3708c8c5 3698 g_MAX5715_device.VRef = 4.096; // MAX5715 12-bit LSB = 0.0010V
whismanoid 0:3edb3708c8c5 3699 SelfTest_print_Vref(cmdLine);
whismanoid 0:3edb3708c8c5 3700 //~ cmdLine.serial().printf("\r\n");
whismanoid 0:3edb3708c8c5 3701 //
whismanoid 0:3edb3708c8c5 3702 // tinyTester.FunctionCall_Expect replaces SelfTest_DACCodeOfVoltage_Expect
whismanoid 0:3edb3708c8c5 3703 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 10.0, 0x0FFF); // overrange FS
whismanoid 0:3edb3708c8c5 3704 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 4.0950, 0x0FFF);
whismanoid 0:3edb3708c8c5 3705 //
whismanoid 0:3edb3708c8c5 3706 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 4.0945, 0x0FFF);
whismanoid 0:3edb3708c8c5 3707 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 4.0944, 0x0FFE);
whismanoid 0:3edb3708c8c5 3708 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 4.0943, 0x0FFE);
whismanoid 0:3edb3708c8c5 3709 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 4.0942, 0x0FFE);
whismanoid 0:3edb3708c8c5 3710 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 4.0941, 0x0FFE);
whismanoid 0:3edb3708c8c5 3711 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 4.0940, 0x0FFE); // search for code transition
whismanoid 0:3edb3708c8c5 3712 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 4.0939, 0x0FFE);
whismanoid 0:3edb3708c8c5 3713 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 4.0938, 0x0FFE);
whismanoid 0:3edb3708c8c5 3714 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 4.0937, 0x0FFE);
whismanoid 0:3edb3708c8c5 3715 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 4.0936, 0x0FFE);
whismanoid 0:3edb3708c8c5 3716 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 4.0935, 0x0FFD);
whismanoid 0:3edb3708c8c5 3717 //
whismanoid 0:3edb3708c8c5 3718 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 4.0930, 0x0FFD);
whismanoid 0:3edb3708c8c5 3719 //
whismanoid 0:3edb3708c8c5 3720 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.0480, 0x0800);
whismanoid 0:3edb3708c8c5 3721 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.0470, 0x07FF);
whismanoid 0:3edb3708c8c5 3722 //
whismanoid 0:3edb3708c8c5 3723 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 1.0000, 0x03E8); // 1.0 volt
whismanoid 0:3edb3708c8c5 3724 //
whismanoid 0:3edb3708c8c5 3725 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0030, 0x0003);
whismanoid 0:3edb3708c8c5 3726 //
whismanoid 0:3edb3708c8c5 3727 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0020, 0x0002);
whismanoid 0:3edb3708c8c5 3728 //
whismanoid 0:3edb3708c8c5 3729 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0010, 0x0001);
whismanoid 0:3edb3708c8c5 3730 //
whismanoid 0:3edb3708c8c5 3731 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0000, 0x0000);
whismanoid 0:3edb3708c8c5 3732 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, -0.0001, 0x0000); // overrange ZS
whismanoid 0:3edb3708c8c5 3733 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, -0.0002, 0x0000); // overrange ZS
whismanoid 0:3edb3708c8c5 3734 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, -1.0, 0x0000); // overrange ZS
whismanoid 0:3edb3708c8c5 3735 //
whismanoid 0:3edb3708c8c5 3736 // tinyTester.FunctionCall_Expect replaces SelfTest_VoltageOfCode_Expect
whismanoid 0:3edb3708c8c5 3737 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x0FFF, 4.0950);
whismanoid 0:3edb3708c8c5 3738 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x0FFE, 4.0940);
whismanoid 0:3edb3708c8c5 3739 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x0800, 2.0480);
whismanoid 0:3edb3708c8c5 3740 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x07FF, 2.0470);
whismanoid 0:3edb3708c8c5 3741 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x03E8, 1.0000); // 1.0 volt
whismanoid 0:3edb3708c8c5 3742 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x0001, 0.0010);
whismanoid 0:3edb3708c8c5 3743 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x0000, 0.0000);
whismanoid 0:3edb3708c8c5 3744 //
whismanoid 0:3edb3708c8c5 3745 //------------------------------------------------------------
whismanoid 0:3edb3708c8c5 3746 cmdLine.serial().printf("\r\n");
whismanoid 0:3edb3708c8c5 3747 g_MAX5715_device.VRef = 2.048; // 12-bit LSB = 0.0005V
whismanoid 0:3edb3708c8c5 3748 SelfTest_print_Vref(cmdLine);
whismanoid 0:3edb3708c8c5 3749 //~ cmdLine.serial().printf("\r\n");
whismanoid 0:3edb3708c8c5 3750 // tinyTester.FunctionCall_Expect replaces SelfTest_DACCodeOfVoltage_Expect
whismanoid 0:3edb3708c8c5 3751 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 10.0, 0x0FFF); // overrange FS
whismanoid 0:3edb3708c8c5 3752 //
whismanoid 0:3edb3708c8c5 3753 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.0480, 0x0FFF);
whismanoid 0:3edb3708c8c5 3754 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.0479, 0x0FFF);
whismanoid 0:3edb3708c8c5 3755 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.0478, 0x0FFF);
whismanoid 0:3edb3708c8c5 3756 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.0477, 0x0FFF);
whismanoid 0:3edb3708c8c5 3757 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.0476, 0x0FFF);
whismanoid 0:3edb3708c8c5 3758 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.0475, 0x0FFF);
whismanoid 0:3edb3708c8c5 3759 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.0474, 0x0FFF);
whismanoid 0:3edb3708c8c5 3760 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.0473, 0x0FFF);
whismanoid 0:3edb3708c8c5 3761 //
whismanoid 0:3edb3708c8c5 3762 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.0472, 0x0FFE);
whismanoid 0:3edb3708c8c5 3763 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.0471, 0x0FFE);
whismanoid 0:3edb3708c8c5 3764 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.0470, 0x0FFE);
whismanoid 0:3edb3708c8c5 3765 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.0469, 0x0FFE);
whismanoid 0:3edb3708c8c5 3766 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.0468, 0x0FFE);
whismanoid 0:3edb3708c8c5 3767 //
whismanoid 0:3edb3708c8c5 3768 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.0467, 0x0FFD);
whismanoid 0:3edb3708c8c5 3769 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.0466, 0x0FFD);
whismanoid 0:3edb3708c8c5 3770 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.0465, 0x0FFD);
whismanoid 0:3edb3708c8c5 3771 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.0464, 0x0FFD);
whismanoid 0:3edb3708c8c5 3772 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.0463, 0x0FFD);
whismanoid 0:3edb3708c8c5 3773 //
whismanoid 0:3edb3708c8c5 3774 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 1.0240, 0x0800);
whismanoid 0:3edb3708c8c5 3775 //
whismanoid 0:3edb3708c8c5 3776 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 1.0235, 0x07FF);
whismanoid 0:3edb3708c8c5 3777 //
whismanoid 0:3edb3708c8c5 3778 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 1.0000, 0x07D0); // 1.0 volt
whismanoid 0:3edb3708c8c5 3779 //
whismanoid 0:3edb3708c8c5 3780 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0017, 0x0003);
whismanoid 0:3edb3708c8c5 3781 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0016, 0x0003);
whismanoid 0:3edb3708c8c5 3782 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0015, 0x0003);
whismanoid 0:3edb3708c8c5 3783 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0014, 0x0003);
whismanoid 0:3edb3708c8c5 3784 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0013, 0x0003);
whismanoid 0:3edb3708c8c5 3785 //
whismanoid 0:3edb3708c8c5 3786 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0012, 0x0002);
whismanoid 0:3edb3708c8c5 3787 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0011, 0x0002);
whismanoid 0:3edb3708c8c5 3788 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0010, 0x0002);
whismanoid 0:3edb3708c8c5 3789 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0009, 0x0002);
whismanoid 0:3edb3708c8c5 3790 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0008, 0x0002);
whismanoid 0:3edb3708c8c5 3791 //
whismanoid 0:3edb3708c8c5 3792 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0007, 0x0001);
whismanoid 0:3edb3708c8c5 3793 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0006, 0x0001);
whismanoid 0:3edb3708c8c5 3794 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0005, 0x0001);
whismanoid 0:3edb3708c8c5 3795 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0004, 0x0001);
whismanoid 0:3edb3708c8c5 3796 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0003, 0x0001);
whismanoid 0:3edb3708c8c5 3797 //
whismanoid 0:3edb3708c8c5 3798 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0002, 0x0000);
whismanoid 0:3edb3708c8c5 3799 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0001, 0x0000);
whismanoid 0:3edb3708c8c5 3800 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0000, 0x0000);
whismanoid 0:3edb3708c8c5 3801 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, -0.0001, 0x0000); // overrange ZS
whismanoid 0:3edb3708c8c5 3802 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, -0.0002, 0x0000); // overrange ZS
whismanoid 0:3edb3708c8c5 3803 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, -1.0, 0x0000); // overrange ZS
whismanoid 0:3edb3708c8c5 3804 // tinyTester.FunctionCall_Expect replaces SelfTest_VoltageOfCode_Expect
whismanoid 0:3edb3708c8c5 3805 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x0FFF, 2.0475);
whismanoid 0:3edb3708c8c5 3806 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x0FFE, 2.0470);
whismanoid 0:3edb3708c8c5 3807 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x0FFD, 2.0465);
whismanoid 0:3edb3708c8c5 3808 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x0800, 1.0240);
whismanoid 0:3edb3708c8c5 3809 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x07FF, 1.0235);
whismanoid 0:3edb3708c8c5 3810 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x07D0, 1.0000); // 1.0 volt
whismanoid 0:3edb3708c8c5 3811 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x0002, 0.0010);
whismanoid 0:3edb3708c8c5 3812 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x0001, 0.0005);
whismanoid 0:3edb3708c8c5 3813 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x0000, 0.0000);
whismanoid 0:3edb3708c8c5 3814 //
whismanoid 0:3edb3708c8c5 3815 //
whismanoid 0:3edb3708c8c5 3816 //------------------------------------------------------------
whismanoid 0:3edb3708c8c5 3817 cmdLine.serial().printf("\r\n");
whismanoid 0:3edb3708c8c5 3818 g_MAX5715_device.VRef = 2.500; // 12-bit LSB = 0.0006105006105006105V
whismanoid 0:3edb3708c8c5 3819 SelfTest_print_Vref(cmdLine);
whismanoid 0:3edb3708c8c5 3820 //~ cmdLine.serial().printf("\r\n");
whismanoid 0:3edb3708c8c5 3821 // tinyTester.FunctionCall_Expect replaces SelfTest_DACCodeOfVoltage_Expect
whismanoid 0:3edb3708c8c5 3822 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 10.0, 0x0FFF); // overrange FS
whismanoid 0:3edb3708c8c5 3823 //
whismanoid 0:3edb3708c8c5 3824 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.5000, 0x0FFF);
whismanoid 0:3edb3708c8c5 3825 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4999, 0x0FFF);
whismanoid 0:3edb3708c8c5 3826 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4998, 0x0FFF);
whismanoid 0:3edb3708c8c5 3827 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4997, 0x0FFF);
whismanoid 0:3edb3708c8c5 3828 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4996, 0x0FFF);
whismanoid 0:3edb3708c8c5 3829 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4995, 0x0FFF);
whismanoid 0:3edb3708c8c5 3830 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4994, 0x0FFF);
whismanoid 0:3edb3708c8c5 3831 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4993, 0x0FFF);
whismanoid 0:3edb3708c8c5 3832 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4992, 0x0FFF);
whismanoid 0:3edb3708c8c5 3833 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4991, 0x0FFF);
whismanoid 0:3edb3708c8c5 3834 //
whismanoid 0:3edb3708c8c5 3835 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4990, 0x0FFE); // search for code transitions
whismanoid 0:3edb3708c8c5 3836 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4989, 0x0FFE);
whismanoid 0:3edb3708c8c5 3837 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4988, 0x0FFE);
whismanoid 0:3edb3708c8c5 3838 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4987, 0x0FFE);
whismanoid 0:3edb3708c8c5 3839 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4986, 0x0FFE);
whismanoid 0:3edb3708c8c5 3840 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4985, 0x0FFE);
whismanoid 0:3edb3708c8c5 3841 //
whismanoid 0:3edb3708c8c5 3842 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4984, 0x0FFD);
whismanoid 0:3edb3708c8c5 3843 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4983, 0x0FFD);
whismanoid 0:3edb3708c8c5 3844 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4982, 0x0FFD);
whismanoid 0:3edb3708c8c5 3845 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4981, 0x0FFD);
whismanoid 0:3edb3708c8c5 3846 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4980, 0x0FFD);
whismanoid 0:3edb3708c8c5 3847 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4979, 0x0FFD);
whismanoid 0:3edb3708c8c5 3848 //
whismanoid 0:3edb3708c8c5 3849 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4978, 0x0FFC);
whismanoid 0:3edb3708c8c5 3850 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4977, 0x0FFC);
whismanoid 0:3edb3708c8c5 3851 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4976, 0x0FFC);
whismanoid 0:3edb3708c8c5 3852 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4975, 0x0FFC);
whismanoid 0:3edb3708c8c5 3853 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4974, 0x0FFC);
whismanoid 0:3edb3708c8c5 3854 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4973, 0x0FFC);
whismanoid 0:3edb3708c8c5 3855 //
whismanoid 0:3edb3708c8c5 3856 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4972, 0x0FFB);
whismanoid 0:3edb3708c8c5 3857 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4971, 0x0FFB);
whismanoid 0:3edb3708c8c5 3858 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 2.4970, 0x0FFB);
whismanoid 0:3edb3708c8c5 3859 //
whismanoid 0:3edb3708c8c5 3860 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 1.2500, 0x0800);
whismanoid 0:3edb3708c8c5 3861 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 1.2494, 0x07FF);
whismanoid 0:3edb3708c8c5 3862 //
whismanoid 0:3edb3708c8c5 3863 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 1.0000, 0x0666); // 1.0 volt
whismanoid 0:3edb3708c8c5 3864 //
whismanoid 0:3edb3708c8c5 3865 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0019, 0x0003); // search for code transitions
whismanoid 0:3edb3708c8c5 3866 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0018, 0x0003);
whismanoid 0:3edb3708c8c5 3867 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0017, 0x0003);
whismanoid 0:3edb3708c8c5 3868 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0016, 0x0003);
whismanoid 0:3edb3708c8c5 3869 //
whismanoid 0:3edb3708c8c5 3870 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0015, 0x0002);
whismanoid 0:3edb3708c8c5 3871 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0014, 0x0002);
whismanoid 0:3edb3708c8c5 3872 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0013, 0x0002);
whismanoid 0:3edb3708c8c5 3873 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0012, 0x0002);
whismanoid 0:3edb3708c8c5 3874 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0011, 0x0002);
whismanoid 0:3edb3708c8c5 3875 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0010, 0x0002);
whismanoid 0:3edb3708c8c5 3876 //
whismanoid 0:3edb3708c8c5 3877 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0009, 0x0001);
whismanoid 0:3edb3708c8c5 3878 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0008, 0x0001);
whismanoid 0:3edb3708c8c5 3879 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0007, 0x0001);
whismanoid 0:3edb3708c8c5 3880 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0006, 0x0001);
whismanoid 0:3edb3708c8c5 3881 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0005, 0x0001);
whismanoid 0:3edb3708c8c5 3882 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0004, 0x0001);
whismanoid 0:3edb3708c8c5 3883 //
whismanoid 0:3edb3708c8c5 3884 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0003, 0x0000);
whismanoid 0:3edb3708c8c5 3885 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0002, 0x0000);
whismanoid 0:3edb3708c8c5 3886 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0001, 0x0000);
whismanoid 0:3edb3708c8c5 3887 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, 0.0000, 0x0000);
whismanoid 0:3edb3708c8c5 3888 //
whismanoid 0:3edb3708c8c5 3889 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, -0.0001, 0x0000); // overrange ZS
whismanoid 0:3edb3708c8c5 3890 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, -0.0002, 0x0000); // overrange ZS
whismanoid 0:3edb3708c8c5 3891 tinyTester.FunctionCall_Expect("MAX5715.DACCodeOfVoltage", fn_MAX5715_DACCodeOfVoltage, -1.0, 0x0000); // overrange ZS
whismanoid 0:3edb3708c8c5 3892 // tinyTester.FunctionCall_Expect replaces SelfTest_VoltageOfCode_Expect
whismanoid 0:3edb3708c8c5 3893 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x0FFF, 2.5000);
whismanoid 0:3edb3708c8c5 3894 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x0FFE, 2.4988);
whismanoid 0:3edb3708c8c5 3895 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x0FFD, 2.4976);
whismanoid 0:3edb3708c8c5 3896 //
whismanoid 0:3edb3708c8c5 3897 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x0800, 1.2500);
whismanoid 0:3edb3708c8c5 3898 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x07FF, 1.2494);
whismanoid 0:3edb3708c8c5 3899 //
whismanoid 0:3edb3708c8c5 3900 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x0667, 1.0000); // 1.0 volt
whismanoid 0:3edb3708c8c5 3901 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x0666, 1.0000); // 1.0 volt
whismanoid 0:3edb3708c8c5 3902 //
whismanoid 0:3edb3708c8c5 3903 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x0002, 0.0012);
whismanoid 0:3edb3708c8c5 3904 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x0001, 0.0006);
whismanoid 0:3edb3708c8c5 3905 tinyTester.FunctionCall_Expect("MAX5715.VoltageOfCode", fn_MAX5715_VoltageOfCode, 0x0000, 0.0000);
whismanoid 0:3edb3708c8c5 3906 //
whismanoid 0:3edb3708c8c5 3907 //
whismanoid 0:3edb3708c8c5 3908 // Device Testing: DAC commands, verify using on-board ADC inputs
whismanoid 0:3edb3708c8c5 3909 //
whismanoid 0:3edb3708c8c5 3910 cmdLine.serial().printf("\r\n MAX5715.Init()");
whismanoid 0:3edb3708c8c5 3911 g_MAX5715_device.Init();
whismanoid 0:3edb3708c8c5 3912 //
whismanoid 0:3edb3708c8c5 3913 uint16_t ch = 0;
whismanoid 0:3edb3708c8c5 3914 uint16_t code = 0xfff;
whismanoid 0:3edb3708c8c5 3915 double voltageV = 0.5;
whismanoid 0:3edb3708c8c5 3916 //
whismanoid 0:3edb3708c8c5 3917 // full-scale output on ch0, test MAX5715 internal REF options
whismanoid 0:3edb3708c8c5 3918 ch = 0;
whismanoid 0:3edb3708c8c5 3919 cmdLine.serial().printf("\r\n MAX5715.CODEnLOADn ch=%d code=%d", ch, code);
whismanoid 0:3edb3708c8c5 3920 g_MAX5715_device.CODEnLOADn(ch, code);
whismanoid 0:3edb3708c8c5 3921 //
whismanoid 0:3edb3708c8c5 3922 cmdLine.serial().printf("\r\n MAX5715.REF(MAX5715::REF_AlwaysOn_2V048)");
whismanoid 0:3edb3708c8c5 3923 g_MAX5715_device.REF(MAX5715::REF_AlwaysOn_2V048);
whismanoid 5:82037e281451 3924 // tinyTester.Wait_Output_Settling replaces wait_ms
whismanoid 0:3edb3708c8c5 3925 tinyTester.Wait_Output_Settling();
whismanoid 5:82037e281451 3926 // tinyTester.AnalogIn0_Read_Expect_voltageV replaces SelfTest_AnalogInput_Expect_ch_V
whismanoid 0:3edb3708c8c5 3927 tinyTester.err_threshold = 0.030; // 30mV
whismanoid 0:3edb3708c8c5 3928 tinyTester.AnalogIn0_Read_Expect_voltageV(2.048);
whismanoid 0:3edb3708c8c5 3929 //
whismanoid 0:3edb3708c8c5 3930 cmdLine.serial().printf("\r\n MAX5715.REF(MAX5715::REF_AlwaysOn_4V096)");
whismanoid 0:3edb3708c8c5 3931 g_MAX5715_device.REF(MAX5715::REF_AlwaysOn_4V096);
whismanoid 0:3edb3708c8c5 3932 // MAX32625MBED 4.096V may be as low as 3.3V supply
whismanoid 5:82037e281451 3933 // tinyTester.Wait_Output_Settling replaces wait_ms
whismanoid 0:3edb3708c8c5 3934 tinyTester.Wait_Output_Settling();
whismanoid 5:82037e281451 3935 // tinyTester.AnalogIn0_Read_Expect_voltageV replaces SelfTest_AnalogInput_Expect_ch_V
whismanoid 0:3edb3708c8c5 3936 tinyTester.err_threshold = 0.50; // 30mV
whismanoid 0:3edb3708c8c5 3937 tinyTester.AnalogIn0_Read_Expect_voltageV(3.750); // accept 3.25V to 4.25V
whismanoid 0:3edb3708c8c5 3938 //
whismanoid 0:3edb3708c8c5 3939 cmdLine.serial().printf("\r\n MAX5715.REF(MAX5715::REF_AlwaysOn_2V500)");
whismanoid 0:3edb3708c8c5 3940 g_MAX5715_device.REF(MAX5715::REF_AlwaysOn_2V500);
whismanoid 5:82037e281451 3941 // tinyTester.Wait_Output_Settling replaces wait_ms
whismanoid 0:3edb3708c8c5 3942 tinyTester.Wait_Output_Settling();
whismanoid 5:82037e281451 3943 // tinyTester.AnalogIn0_Read_Expect_voltageV replaces SelfTest_AnalogInput_Expect_ch_V
whismanoid 0:3edb3708c8c5 3944 tinyTester.err_threshold = 0.030; // 30mV
whismanoid 0:3edb3708c8c5 3945 tinyTester.AnalogIn0_Read_Expect_voltageV(2.500);
whismanoid 0:3edb3708c8c5 3946 //
whismanoid 0:3edb3708c8c5 3947 // test the individual channel outputs
whismanoid 0:3edb3708c8c5 3948 ch = 0;
whismanoid 0:3edb3708c8c5 3949 voltageV = 0.5;
whismanoid 0:3edb3708c8c5 3950 code = g_MAX5715_device.DACCodeOfVoltage(voltageV);
whismanoid 0:3edb3708c8c5 3951 cmdLine.serial().printf("\r\n MAX5715.CODEnLOADn ch=%d code=%d", ch, code);
whismanoid 0:3edb3708c8c5 3952 g_MAX5715_device.CODEnLOADn(ch, code);
whismanoid 5:82037e281451 3953 // tinyTester.Wait_Output_Settling replaces wait_ms
whismanoid 0:3edb3708c8c5 3954 tinyTester.Wait_Output_Settling();
whismanoid 5:82037e281451 3955 // tinyTester.AnalogIn0_Read_Expect_voltageV replaces SelfTest_AnalogInput_Expect_ch_V
whismanoid 0:3edb3708c8c5 3956 tinyTester.err_threshold = 0.030; // 30mV
whismanoid 0:3edb3708c8c5 3957 tinyTester.AnalogIn0_Read_Expect_voltageV(voltageV);
whismanoid 0:3edb3708c8c5 3958 //
whismanoid 0:3edb3708c8c5 3959 ch = 1;
whismanoid 0:3edb3708c8c5 3960 voltageV = 0.2;
whismanoid 0:3edb3708c8c5 3961 code = g_MAX5715_device.DACCodeOfVoltage(voltageV);
whismanoid 0:3edb3708c8c5 3962 cmdLine.serial().printf("\r\n MAX5715.CODEnLOADn ch=%d code=%d", ch, code);
whismanoid 0:3edb3708c8c5 3963 g_MAX5715_device.CODEnLOADn(ch, code);
whismanoid 5:82037e281451 3964 // tinyTester.Wait_Output_Settling replaces wait_ms
whismanoid 0:3edb3708c8c5 3965 tinyTester.Wait_Output_Settling();
whismanoid 5:82037e281451 3966 // tinyTester.AnalogIn0_Read_Expect_voltageV replaces SelfTest_AnalogInput_Expect_ch_V
whismanoid 0:3edb3708c8c5 3967 tinyTester.err_threshold = 0.030; // 30mV
whismanoid 0:3edb3708c8c5 3968 tinyTester.AnalogIn1_Read_Expect_voltageV(voltageV);
whismanoid 0:3edb3708c8c5 3969 //
whismanoid 0:3edb3708c8c5 3970 ch = 2;
whismanoid 0:3edb3708c8c5 3971 voltageV = 0.4;
whismanoid 0:3edb3708c8c5 3972 code = g_MAX5715_device.DACCodeOfVoltage(voltageV);
whismanoid 0:3edb3708c8c5 3973 cmdLine.serial().printf("\r\n MAX5715.CODEnLOADn ch=%d code=%d", ch, code);
whismanoid 0:3edb3708c8c5 3974 g_MAX5715_device.CODEnLOADn(ch, code);
whismanoid 5:82037e281451 3975 // tinyTester.Wait_Output_Settling replaces wait_ms
whismanoid 0:3edb3708c8c5 3976 tinyTester.Wait_Output_Settling();
whismanoid 5:82037e281451 3977 // tinyTester.AnalogIn0_Read_Expect_voltageV replaces SelfTest_AnalogInput_Expect_ch_V
whismanoid 0:3edb3708c8c5 3978 tinyTester.err_threshold = 0.030; // 30mV
whismanoid 0:3edb3708c8c5 3979 tinyTester.AnalogIn2_Read_Expect_voltageV(voltageV);
whismanoid 0:3edb3708c8c5 3980 //
whismanoid 0:3edb3708c8c5 3981 ch = 3;
whismanoid 0:3edb3708c8c5 3982 voltageV = 0.25;
whismanoid 0:3edb3708c8c5 3983 code = g_MAX5715_device.DACCodeOfVoltage(voltageV);
whismanoid 0:3edb3708c8c5 3984 cmdLine.serial().printf("\r\n MAX5715.CODEnLOADn ch=%d code=%d", ch, code);
whismanoid 0:3edb3708c8c5 3985 g_MAX5715_device.CODEnLOADn(ch, code);
whismanoid 5:82037e281451 3986 // tinyTester.Wait_Output_Settling replaces wait_ms
whismanoid 0:3edb3708c8c5 3987 tinyTester.Wait_Output_Settling();
whismanoid 5:82037e281451 3988 // tinyTester.AnalogIn0_Read_Expect_voltageV replaces SelfTest_AnalogInput_Expect_ch_V
whismanoid 0:3edb3708c8c5 3989 tinyTester.err_threshold = 0.030; // 30mV
whismanoid 0:3edb3708c8c5 3990 tinyTester.AnalogIn3_Read_Expect_voltageV(voltageV);
whismanoid 0:3edb3708c8c5 3991 //
whismanoid 0:3edb3708c8c5 3992 // test that the channels are independent
whismanoid 0:3edb3708c8c5 3993 tinyTester.AnalogIn0_Read_Expect_voltageV(g_MAX5715_device.VoltageOfCode(g_MAX5715_device.CODE[0]));
whismanoid 0:3edb3708c8c5 3994 tinyTester.AnalogIn1_Read_Expect_voltageV(g_MAX5715_device.VoltageOfCode(g_MAX5715_device.CODE[1]));
whismanoid 0:3edb3708c8c5 3995 tinyTester.AnalogIn2_Read_Expect_voltageV(g_MAX5715_device.VoltageOfCode(g_MAX5715_device.CODE[2]));
whismanoid 0:3edb3708c8c5 3996 tinyTester.AnalogIn3_Read_Expect_voltageV(g_MAX5715_device.VoltageOfCode(g_MAX5715_device.CODE[3]));
whismanoid 0:3edb3708c8c5 3997 //
whismanoid 0:3edb3708c8c5 3998 #elif APPLICATION_MAX11131
whismanoid 0:3edb3708c8c5 3999 //
whismanoid 0:3edb3708c8c5 4000 // MAX11131BOB self-test functions
whismanoid 0:3edb3708c8c5 4001 //~ SelfTest_FAIL(cmdLine);
whismanoid 0:3edb3708c8c5 4002 //~ cmdLine.serial().printf("test program not implemented yet");
whismanoid 0:3edb3708c8c5 4003 int16_t value_u12;
whismanoid 0:3edb3708c8c5 4004 int channelId;
whismanoid 0:3edb3708c8c5 4005 double voltageV = 0.5;
whismanoid 0:3edb3708c8c5 4006 //
whismanoid 0:3edb3708c8c5 4007 //cmdLine.serial().printf("\r\n 0.0: MAX11131.Init()");
whismanoid 0:3edb3708c8c5 4008 //g_MAX11131_device.Init();
whismanoid 0:3edb3708c8c5 4009 //
whismanoid 0:3edb3708c8c5 4010 // Device Testing: ADC commands, verify with on-board ADC and SPI framing
whismanoid 0:3edb3708c8c5 4011 //
whismanoid 0:3edb3708c8c5 4012 // MAX11131 SelfTest: MAX11131 SPI connections (Power Supply and GND, SCLK, MOSI, MISO, CS)
whismanoid 0:3edb3708c8c5 4013 cmdLine.serial().printf("\r\n");
whismanoid 0:3edb3708c8c5 4014 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 4015 "\r\n 1.0: Test SCAN_0100_StandardExt -- verify SPI (VDD, GND, SCLK, MOSI, MISO, CS)");
whismanoid 0:3edb3708c8c5 4016 cmdLine.serial().printf("\r\n MAX11131.Init()");
whismanoid 0:3edb3708c8c5 4017 g_MAX11131_device.Init();
whismanoid 0:3edb3708c8c5 4018 // Send MOSI data Expect MISO data Description
whismanoid 0:3edb3708c8c5 4019 // 1000_0000_0000_0000 xxxx_xxxx_xxxx_xxxx ADC_CONFIGURATION REFSEL=0 SPM[1:0]=0 ECHO=0
whismanoid 0:3edb3708c8c5 4020 // 0010_0111_1010_0100 xxxx_xxxx_xxxx_xxxx ADC_MODE_CONTROL SCAN_0100_StandardExt CHSEL=15 RESET=1 CHANID=1
whismanoid 0:3edb3708c8c5 4021 // 0000_0000_0000_0000 0000_xxxx_xxxx_xxxx Channel ID tag = AIN0 expect high nybble 0
whismanoid 0:3edb3708c8c5 4022 // 0000_0000_0000_0000 0001_xxxx_xxxx_xxxx Channel ID tag = AIN1 expect high nybble 1
whismanoid 0:3edb3708c8c5 4023 // 0000_0000_0000_0000 0010_xxxx_xxxx_xxxx Channel ID tag = AIN2 expect high nybble 2
whismanoid 0:3edb3708c8c5 4024 // 0000_0000_0000_0000 0011_xxxx_xxxx_xxxx Channel ID tag = AIN3 expect high nybble 3
whismanoid 0:3edb3708c8c5 4025 //
whismanoid 0:3edb3708c8c5 4026 cmdLine.serial().printf("\r\n MOSI <-- 1000_0000_0000_0000 ADC_CONFIGURATION REFSEL=0 SPM[1:0]=0 ECHO=0");
whismanoid 0:3edb3708c8c5 4027 g_MAX11131_device.SPIoutputCS(0); // drive CS low
whismanoid 0:3edb3708c8c5 4028 g_MAX11131_device.SPIwrite16bits(0x8000);
whismanoid 0:3edb3708c8c5 4029 g_MAX11131_device.SPIoutputCS(1); // drive CS high
whismanoid 0:3edb3708c8c5 4030 //
whismanoid 0:3edb3708c8c5 4031 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 4032 "\r\n MOSI <-- 0010_0111_1010_0100 ADC_MODE_CONTROL SCAN_0100_StandardExt CHSEL=15 RESET=1 CHANID=1");
whismanoid 0:3edb3708c8c5 4033 g_MAX11131_device.SPIoutputCS(0); // drive CS low
whismanoid 0:3edb3708c8c5 4034 g_MAX11131_device.SPIwrite16bits(0x27a4);
whismanoid 0:3edb3708c8c5 4035 g_MAX11131_device.SPIoutputCS(1); // drive CS high
whismanoid 0:3edb3708c8c5 4036 //
whismanoid 0:3edb3708c8c5 4037 for (int channelIndex = 0; channelIndex < 16; channelIndex++) {
whismanoid 0:3edb3708c8c5 4038 //~ cmdLine.serial().printf("\r\n MISO --> expect 0000_xxxx_xxxx_xxxx");
whismanoid 0:3edb3708c8c5 4039 g_MAX11131_device.SPIoutputCS(0); // drive CS low
whismanoid 0:3edb3708c8c5 4040 g_MAX11131_device.RAW_misoData16[channelIndex] = g_MAX11131_device.SPIread16bits();
whismanoid 0:3edb3708c8c5 4041 g_MAX11131_device.SPIoutputCS(1); // drive CS high
whismanoid 0:3edb3708c8c5 4042 int expect_channelId = channelIndex;
whismanoid 0:3edb3708c8c5 4043 int actual_channelId = (g_MAX11131_device.RAW_misoData16[channelIndex] >> 12) & 0x000F;
whismanoid 0:3edb3708c8c5 4044 if (actual_channelId != expect_channelId)
whismanoid 0:3edb3708c8c5 4045 {
whismanoid 3:8913cb4a8b9f 4046 tinyTester.FAIL();
whismanoid 0:3edb3708c8c5 4047 cmdLine.serial().printf("MISO --> 0x%4.4x", (g_MAX11131_device.RAW_misoData16[channelIndex] & 0xFFFF));
whismanoid 0:3edb3708c8c5 4048 cmdLine.serial().printf(" expect 0x%1.1xxxx (channel ID %d)", expect_channelId, expect_channelId);
whismanoid 0:3edb3708c8c5 4049 cmdLine.serial().printf(" but got 0x%1.1xxxx", actual_channelId);
whismanoid 0:3edb3708c8c5 4050 }
whismanoid 0:3edb3708c8c5 4051 else
whismanoid 0:3edb3708c8c5 4052 {
whismanoid 3:8913cb4a8b9f 4053 tinyTester.PASS();
whismanoid 0:3edb3708c8c5 4054 cmdLine.serial().printf("MISO --> 0x%4.4x", (g_MAX11131_device.RAW_misoData16[channelIndex] & 0xFFFF));
whismanoid 0:3edb3708c8c5 4055 cmdLine.serial().printf(" expect 0x%1.1xxxx (channel ID %d)", expect_channelId, expect_channelId);
whismanoid 0:3edb3708c8c5 4056 }
whismanoid 0:3edb3708c8c5 4057 }
whismanoid 0:3edb3708c8c5 4058 //
whismanoid 5:82037e281451 4059 // MAX11131 SelfTest: MAX11131 Supports Internal Clock Modes (CNVST, EOC)
whismanoid 0:3edb3708c8c5 4060 cmdLine.serial().printf("\r\n");
whismanoid 0:3edb3708c8c5 4061 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 4062 "\r\n 1.1: Test SCAN_0011_StandardInt -- verify Internal Clock signals (CNVST, EOC)");
whismanoid 0:3edb3708c8c5 4063 cmdLine.serial().printf("\r\n MAX11131.Init()");
whismanoid 0:3edb3708c8c5 4064 g_MAX11131_device.Init();
whismanoid 0:3edb3708c8c5 4065 g_MAX11131_device.SPIoutputCS(0); // drive CS low
whismanoid 0:3edb3708c8c5 4066 g_MAX11131_device.RAW_misoData16[0] = g_MAX11131_device.SPIread16bits();
whismanoid 0:3edb3708c8c5 4067 g_MAX11131_device.SPIoutputCS(1); // drive CS high
whismanoid 3:8913cb4a8b9f 4068 //
whismanoid 5:82037e281451 4069 // tinyTester.DigitalIn_Read_Expect_WarnOnly replaces SelfTest_MAX11131_EOC_expect
whismanoid 3:8913cb4a8b9f 4070 tinyTester.DigitalIn_Read_Expect_WarnOnly(EOCb_pin, "EOC", 1, "initial value before sending commands");
whismanoid 3:8913cb4a8b9f 4071 //
whismanoid 0:3edb3708c8c5 4072 // Send MOSI data Expect MISO data Description
whismanoid 0:3edb3708c8c5 4073 // 1000_0000_0000_0000 xxxx_xxxx_xxxx_xxxx ADC_CONFIGURATION REFSEL=0 SPM[1:0]=0 ECHO=0 No Averaging
whismanoid 0:3edb3708c8c5 4074 // 0001_1001_1010_0000 xxxx_xxxx_xxxx_xxxx ADC_MODE_CONTROL SCAN_0011_StandardInt CHSEL=3 RESET=1 SWCNV=0
whismanoid 0:3edb3708c8c5 4075 // 0000_0000_0000_0000 0000_xxxx_xxxx_xxxx Channel ID tag = AIN0 expect high nybble 0
whismanoid 0:3edb3708c8c5 4076 // 0000_0000_0000_0000 0001_xxxx_xxxx_xxxx Channel ID tag = AIN1 expect high nybble 1
whismanoid 0:3edb3708c8c5 4077 // 0000_0000_0000_0000 0010_xxxx_xxxx_xxxx Channel ID tag = AIN2 expect high nybble 2
whismanoid 0:3edb3708c8c5 4078 // 0000_0000_0000_0000 0011_xxxx_xxxx_xxxx Channel ID tag = AIN3 expect high nybble 3
whismanoid 0:3edb3708c8c5 4079 //
whismanoid 0:3edb3708c8c5 4080 cmdLine.serial().printf("\r\n MOSI <-- 1000_0000_0000_0000 ADC_CONFIGURATION REFSEL=0 SPM[1:0]=0 ECHO=0");
whismanoid 0:3edb3708c8c5 4081 g_MAX11131_device.SPIoutputCS(0); // drive CS low
whismanoid 0:3edb3708c8c5 4082 g_MAX11131_device.SPIwrite16bits(0x8000);
whismanoid 0:3edb3708c8c5 4083 g_MAX11131_device.SPIoutputCS(1); // drive CS high
whismanoid 0:3edb3708c8c5 4084 //
whismanoid 0:3edb3708c8c5 4085 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 4086 "\r\n MOSI <-- 0001_1001_1010_0000 ADC_MODE_CONTROL SCAN_0011_StandardInt CHSEL=3 RESET=1 SWCNV=0");
whismanoid 0:3edb3708c8c5 4087 g_MAX11131_device.SPIoutputCS(0); // drive CS low
whismanoid 0:3edb3708c8c5 4088 g_MAX11131_device.SPIwrite16bits(0x19a0);
whismanoid 0:3edb3708c8c5 4089 g_MAX11131_device.SPIoutputCS(1); // drive CS high
whismanoid 0:3edb3708c8c5 4090 //
whismanoid 0:3edb3708c8c5 4091 for (int channelIndex = 0; channelIndex < 4; channelIndex++) {
whismanoid 0:3edb3708c8c5 4092 //~ cmdLine.serial().printf("\r\n MISO --> expect 0000_xxxx_xxxx_xxxx");
whismanoid 0:3edb3708c8c5 4093 //~ wait_ms(200); // delay
whismanoid 0:3edb3708c8c5 4094 g_MAX11131_device.CNVSToutputPulseLow();
whismanoid 0:3edb3708c8c5 4095 //~ g_MAX11131_device.CNVSToutputValue(0);
whismanoid 0:3edb3708c8c5 4096 //~ wait_ms(100); // delay
whismanoid 0:3edb3708c8c5 4097 //~ g_MAX11131_device.CNVSToutputValue(1);
whismanoid 0:3edb3708c8c5 4098 // g_MAX11131_device.EOCinputWaitUntilLow(); // infinite wait hazard, need to fail if timeout exceeded
whismanoid 5:82037e281451 4099 // tinyTester.DigitalIn_Read_Expect_WarnOnly replaces SelfTest_MAX11131_EOC_expect
whismanoid 3:8913cb4a8b9f 4100 tinyTester.DigitalIn_Read_Expect_WarnOnly(EOCb_pin, "EOC", 0, "after CNVST pulse");
whismanoid 0:3edb3708c8c5 4101 g_MAX11131_device.SPIoutputCS(0); // drive CS low
whismanoid 0:3edb3708c8c5 4102 g_MAX11131_device.RAW_misoData16[channelIndex] = g_MAX11131_device.SPIread16bits();
whismanoid 0:3edb3708c8c5 4103 g_MAX11131_device.SPIoutputCS(1); // drive CS high
whismanoid 5:82037e281451 4104 // tinyTester.DigitalIn_Read_Expect_WarnOnly replaces SelfTest_MAX11131_EOC_expect
whismanoid 3:8913cb4a8b9f 4105 tinyTester.DigitalIn_Read_Expect_WarnOnly(EOCb_pin, "EOC", 1, "after SPI read");
whismanoid 0:3edb3708c8c5 4106 int expect_channelId = channelIndex;
whismanoid 0:3edb3708c8c5 4107 int actual_channelId = (g_MAX11131_device.RAW_misoData16[channelIndex] >> 12) & 0x000F;
whismanoid 0:3edb3708c8c5 4108 if (actual_channelId != expect_channelId)
whismanoid 0:3edb3708c8c5 4109 {
whismanoid 3:8913cb4a8b9f 4110 tinyTester.FAIL();
whismanoid 0:3edb3708c8c5 4111 cmdLine.serial().printf("MISO --> 0x%4.4x", (g_MAX11131_device.RAW_misoData16[channelIndex] & 0xFFFF));
whismanoid 0:3edb3708c8c5 4112 cmdLine.serial().printf(" expect 0x%1.1xxxx (channel ID %d)", expect_channelId, expect_channelId);
whismanoid 0:3edb3708c8c5 4113 cmdLine.serial().printf(" but got 0x%1.1xxxx", actual_channelId);
whismanoid 0:3edb3708c8c5 4114 }
whismanoid 0:3edb3708c8c5 4115 else
whismanoid 0:3edb3708c8c5 4116 {
whismanoid 3:8913cb4a8b9f 4117 tinyTester.PASS();
whismanoid 0:3edb3708c8c5 4118 cmdLine.serial().printf("MISO --> 0x%4.4x", (g_MAX11131_device.RAW_misoData16[channelIndex] & 0xFFFF));
whismanoid 0:3edb3708c8c5 4119 cmdLine.serial().printf(" expect 0x%1.1xxxx (channel ID %d)", expect_channelId, expect_channelId);
whismanoid 0:3edb3708c8c5 4120 }
whismanoid 0:3edb3708c8c5 4121 }
whismanoid 0:3edb3708c8c5 4122 //
whismanoid 5:82037e281451 4123 // MAX11131 SelfTest: Test Fixture: MAX541ACPA+ to MAX32625MBED.AIN0/AIN4
whismanoid 0:3edb3708c8c5 4124 // Test Fixture: MAX541 connected to spi2
whismanoid 0:3edb3708c8c5 4125 // SPI spi2_max541(SPI2_MOSI, SPI2_MISO, SPI2_SCK); // mosi, miso, sclk spi2 TARGET_MAX32635MBED: P2_5 P2_6 P2_4 Arduino 2x3-pin header; microSD
whismanoid 0:3edb3708c8c5 4126 // DigitalOut spi2_max541_cs(SPI2_SS); // TARGET_MAX32635MBED: P2_7 Arduino 2x3-pin header
whismanoid 0:3edb3708c8c5 4127 // Test Fixture: MAX541 spi2 init
whismanoid 0:3edb3708c8c5 4128 cmdLine.serial().printf("\r\n");
whismanoid 0:3edb3708c8c5 4129 cmdLine.serial().printf("\r\n 2.0: Test Fixture: MAX541 connected to spi2 (P2.4 P2.5 P2.7)?");
whismanoid 0:3edb3708c8c5 4130 bool SelfTest_has_max541 = false;
whismanoid 0:3edb3708c8c5 4131 // Check actual MAX541 reference voltage
whismanoid 0:3edb3708c8c5 4132 cmdLine.serial().printf("\r\n Test Fixture: MAX541 midscale voltage measure with MAX32625MBED AIN0/4");
whismanoid 0:3edb3708c8c5 4133 max541.Set_Code(0x8000); // we don't know the fullscale voltage yet, so set code to midscale
whismanoid 5:82037e281451 4134 tinyTester.Wait_Output_Settling(); // wait for MAX541 to settle
whismanoid 5:82037e281451 4135 //
whismanoid 0:3edb3708c8c5 4136 double max541_midscale_V = analogInPin_fullScaleVoltage[4] * analogIn4.read(); // TARGET_MAX32630 J1.5 AIN_4 = AIN0 / 5.0 fullscale is 6.0V
whismanoid 0:3edb3708c8c5 4137 const int average_count = 100;
whismanoid 0:3edb3708c8c5 4138 const double average_K = 0.25;
whismanoid 0:3edb3708c8c5 4139 for (int count = 0; count < average_count; count++) {
whismanoid 0:3edb3708c8c5 4140 double measurement_V = analogInPin_fullScaleVoltage[4] * analogIn4.read(); // TARGET_MAX32630 J1.5 AIN_4 = AIN0 / 5.0 fullscale is 6.0V
whismanoid 0:3edb3708c8c5 4141 max541_midscale_V = ((1 - average_K) * max541_midscale_V) + (average_K * measurement_V);
whismanoid 0:3edb3708c8c5 4142 }
whismanoid 0:3edb3708c8c5 4143 if (max541_midscale_V > 1.0f) {
whismanoid 0:3edb3708c8c5 4144 max541.VRef = 2.0 * max541_midscale_V;
whismanoid 0:3edb3708c8c5 4145 cmdLine.serial().printf("\r\n Test Fixture: MAX541 midscale = %1.3fV, so fullscale = %1.3fV",
whismanoid 0:3edb3708c8c5 4146 max541_midscale_V, max541.VRef);
whismanoid 0:3edb3708c8c5 4147 // Detect whether MAX541 is really connected to MAX32625MBED.AIN0/AIN4
whismanoid 0:3edb3708c8c5 4148 voltageV = 1.0f;
whismanoid 0:3edb3708c8c5 4149 SelfTest_has_max541 = SelfTest_MAX541_Voltage(cmdLine, max541, voltageV);
whismanoid 0:3edb3708c8c5 4150 }
whismanoid 0:3edb3708c8c5 4151 if (SelfTest_has_max541) {
whismanoid 0:3edb3708c8c5 4152 voltageV = 0.0f;
whismanoid 0:3edb3708c8c5 4153 SelfTest_has_max541 = SelfTest_MAX541_Voltage(cmdLine, max541, voltageV);
whismanoid 0:3edb3708c8c5 4154 }
whismanoid 0:3edb3708c8c5 4155 if (SelfTest_has_max541) {
whismanoid 5:82037e281451 4156 voltageV = 2.7f;
whismanoid 0:3edb3708c8c5 4157 SelfTest_has_max541 = SelfTest_MAX541_Voltage(cmdLine, max541, voltageV);
whismanoid 0:3edb3708c8c5 4158 }
whismanoid 0:3edb3708c8c5 4159 if (SelfTest_has_max541) {
whismanoid 0:3edb3708c8c5 4160 voltageV = 1.65f;
whismanoid 0:3edb3708c8c5 4161 SelfTest_has_max541 = SelfTest_MAX541_Voltage(cmdLine, max541, voltageV);
whismanoid 0:3edb3708c8c5 4162 }
whismanoid 0:3edb3708c8c5 4163 if (SelfTest_has_max541) {
whismanoid 0:3edb3708c8c5 4164 voltageV = 2.0f;
whismanoid 0:3edb3708c8c5 4165 SelfTest_has_max541 = SelfTest_MAX541_Voltage(cmdLine, max541, voltageV);
whismanoid 0:3edb3708c8c5 4166 }
whismanoid 0:3edb3708c8c5 4167 if (SelfTest_has_max541) {
whismanoid 0:3edb3708c8c5 4168 voltageV = 0.25f;
whismanoid 0:3edb3708c8c5 4169 SelfTest_has_max541 = SelfTest_MAX541_Voltage(cmdLine, max541, voltageV);
whismanoid 0:3edb3708c8c5 4170 }
whismanoid 0:3edb3708c8c5 4171 if (SelfTest_has_max541) {
whismanoid 0:3edb3708c8c5 4172 voltageV = 0.5f;
whismanoid 0:3edb3708c8c5 4173 SelfTest_has_max541 = SelfTest_MAX541_Voltage(cmdLine, max541, voltageV);
whismanoid 0:3edb3708c8c5 4174 }
whismanoid 0:3edb3708c8c5 4175 if (SelfTest_has_max541) {
whismanoid 0:3edb3708c8c5 4176 voltageV = 1.0f;
whismanoid 0:3edb3708c8c5 4177 SelfTest_has_max541 = SelfTest_MAX541_Voltage(cmdLine, max541, voltageV);
whismanoid 0:3edb3708c8c5 4178 }
whismanoid 0:3edb3708c8c5 4179 if (SelfTest_has_max541 == false) {
whismanoid 0:3edb3708c8c5 4180 // don't fail just because we're missing the test fixture...
whismanoid 0:3edb3708c8c5 4181 cmdLine.serial().printf("\r\n Test Fixture: MAX541 not present");
whismanoid 0:3edb3708c8c5 4182 //~ g_SelfTest_nFail--;
whismanoid 0:3edb3708c8c5 4183 }
whismanoid 0:3edb3708c8c5 4184 //
whismanoid 0:3edb3708c8c5 4185 // TODO1: MAX11131 SelfTest: if Test Fixture: drive MAX541, compare MAX32625MBED.AIN0/AIN4 and MAX11131 AIN0
whismanoid 0:3edb3708c8c5 4186 // indirectly verify the reference voltage by reading a known input voltage
whismanoid 0:3edb3708c8c5 4187 if (SelfTest_has_max541) {
whismanoid 0:3edb3708c8c5 4188 cmdLine.serial().printf("\r\n");
whismanoid 0:3edb3708c8c5 4189 cmdLine.serial().printf("\r\n 2.1: TODO1: Check MAX11131 reference voltage using SCAN_0001_Manual");
whismanoid 0:3edb3708c8c5 4190 voltageV = 1.0f;
whismanoid 0:3edb3708c8c5 4191 SelfTest_MAX541_Voltage(cmdLine, max541, voltageV);
whismanoid 0:3edb3708c8c5 4192 cmdLine.serial().printf("\r\n MAX11131.Init()");
whismanoid 0:3edb3708c8c5 4193 g_MAX11131_device.Init();
whismanoid 0:3edb3708c8c5 4194 // 1 ScanManual ch=0 pm=0 id=1
whismanoid 0:3edb3708c8c5 4195 g_MAX11131_device.channelNumber_0_15 = 0;
whismanoid 0:3edb3708c8c5 4196 g_MAX11131_device.PowerManagement_0_2 = 0;
whismanoid 0:3edb3708c8c5 4197 g_MAX11131_device.chan_id_0_1 = 1;
whismanoid 0:3edb3708c8c5 4198 cmdLine.serial().printf("\r\n MAX11131.channelNumber_0_15=%d", g_MAX11131_device.channelNumber_0_15);
whismanoid 0:3edb3708c8c5 4199 cmdLine.serial().printf("\r\n MAX11131.PowerManagement_0_2=%d", g_MAX11131_device.PowerManagement_0_2);
whismanoid 0:3edb3708c8c5 4200 cmdLine.serial().printf("\r\n MAX11131.chan_id_0_1=%d", g_MAX11131_device.chan_id_0_1);
whismanoid 0:3edb3708c8c5 4201 g_MAX11131_device.NumWords = g_MAX11131_device.ScanManual();
whismanoid 0:3edb3708c8c5 4202 cmdLine.serial().printf("\r\n MAX11131.ScanManual -- NumWords = %d",
whismanoid 0:3edb3708c8c5 4203 g_MAX11131_device.NumWords);
whismanoid 0:3edb3708c8c5 4204 g_MAX11131_device.NumWords = g_MAX11131_device.ScanManual();
whismanoid 0:3edb3708c8c5 4205 g_MAX11131_device.ReadAINcode();
whismanoid 0:3edb3708c8c5 4206 cmdLine.serial().printf("\r\n MAX11131.ReadAINcode");
whismanoid 0:3edb3708c8c5 4207 AINcode_print_value_externalClock(cmdLine, g_MAX11131_device.NumWords);
whismanoid 0:3edb3708c8c5 4208 //
whismanoid 0:3edb3708c8c5 4209 // 2.1: TODO1: Check MAX11131 reference voltage -- why we read 0xffff 2.4999V here?
whismanoid 0:3edb3708c8c5 4210 //
whismanoid 0:3edb3708c8c5 4211 cmdLine.serial().printf("\r\n MAX11131.ScanManual -- NumWords = %d",
whismanoid 0:3edb3708c8c5 4212 g_MAX11131_device.NumWords);
whismanoid 0:3edb3708c8c5 4213 // Read raw ADC codes from device into AINcode[] and RAW_misoData16[]
whismanoid 0:3edb3708c8c5 4214 // @pre one of the MAX11311_Scan functions was called, setting g_MAX11131_device.NumWords
whismanoid 0:3edb3708c8c5 4215 g_MAX11131_device.ReadAINcode();
whismanoid 0:3edb3708c8c5 4216 cmdLine.serial().printf("\r\n MAX11131.ReadAINcode");
whismanoid 0:3edb3708c8c5 4217 AINcode_print_value_externalClock(cmdLine, g_MAX11131_device.NumWords);
whismanoid 0:3edb3708c8c5 4218 //
whismanoid 0:3edb3708c8c5 4219 // 2.1: TODO1: Check MAX11131 reference voltage -- why we read 0xffff 2.4999V here?
whismanoid 0:3edb3708c8c5 4220 //
whismanoid 0:3edb3708c8c5 4221 // compare with mbed/Arduino AIN0-AIN3
whismanoid 0:3edb3708c8c5 4222 // MAX32625MBED.AIN4 = MAX11131.AIN0
whismanoid 0:3edb3708c8c5 4223 channelId = 0;
whismanoid 0:3edb3708c8c5 4224 value_u12 = g_MAX11131_device.AINcode[channelId];
whismanoid 0:3edb3708c8c5 4225 voltageV = g_MAX11131_device.VoltageOfCode(value_u12, channelId);
whismanoid 3:8913cb4a8b9f 4226 //
whismanoid 5:82037e281451 4227 // tinyTester.Wait_Output_Settling replaces wait_ms
whismanoid 3:8913cb4a8b9f 4228 tinyTester.Wait_Output_Settling();
whismanoid 5:82037e281451 4229 // tinyTester.AnalogIn0_Read_Expect_voltageV replaces SelfTest_AnalogInput_Expect_ch_V
whismanoid 3:8913cb4a8b9f 4230 tinyTester.err_threshold = 0.100;
whismanoid 3:8913cb4a8b9f 4231 tinyTester.AnalogIn0_Read_Expect_voltageV(voltageV);
whismanoid 3:8913cb4a8b9f 4232 //
whismanoid 0:3edb3708c8c5 4233 }
whismanoid 0:3edb3708c8c5 4234 //
whismanoid 0:3edb3708c8c5 4235 if (SelfTest_has_max541) {
whismanoid 0:3edb3708c8c5 4236 voltageV = 1.0f;
whismanoid 0:3edb3708c8c5 4237 SelfTest_MAX541_Voltage(cmdLine, max541, voltageV);
whismanoid 0:3edb3708c8c5 4238 }
whismanoid 0:3edb3708c8c5 4239 cmdLine.serial().printf("\r\n");
whismanoid 0:3edb3708c8c5 4240 cmdLine.serial().printf("\r\n 3.1: Test SCAN_0001_Manual");
whismanoid 0:3edb3708c8c5 4241 cmdLine.serial().printf("\r\n MAX11131.Init()");
whismanoid 0:3edb3708c8c5 4242 g_MAX11131_device.Init();
whismanoid 0:3edb3708c8c5 4243 // 1 ScanManual ch=0 pm=0 id=1
whismanoid 0:3edb3708c8c5 4244 g_MAX11131_device.channelNumber_0_15 = 0;
whismanoid 0:3edb3708c8c5 4245 g_MAX11131_device.PowerManagement_0_2 = 0;
whismanoid 0:3edb3708c8c5 4246 g_MAX11131_device.chan_id_0_1 = 1;
whismanoid 0:3edb3708c8c5 4247 cmdLine.serial().printf("\r\n MAX11131.channelNumber_0_15=%d", g_MAX11131_device.channelNumber_0_15);
whismanoid 0:3edb3708c8c5 4248 cmdLine.serial().printf("\r\n MAX11131.PowerManagement_0_2=%d", g_MAX11131_device.PowerManagement_0_2);
whismanoid 0:3edb3708c8c5 4249 cmdLine.serial().printf("\r\n MAX11131.chan_id_0_1=%d", g_MAX11131_device.chan_id_0_1);
whismanoid 0:3edb3708c8c5 4250 g_MAX11131_device.NumWords = g_MAX11131_device.ScanManual();
whismanoid 0:3edb3708c8c5 4251 cmdLine.serial().printf("\r\n MAX11131.ScanManual -- NumWords = %d",
whismanoid 0:3edb3708c8c5 4252 g_MAX11131_device.NumWords);
whismanoid 0:3edb3708c8c5 4253 // Read raw ADC codes from device into AINcode[] and RAW_misoData16[]
whismanoid 0:3edb3708c8c5 4254 // @pre one of the MAX11311_Scan functions was called, setting g_MAX11131_device.NumWords
whismanoid 0:3edb3708c8c5 4255 g_MAX11131_device.ReadAINcode();
whismanoid 0:3edb3708c8c5 4256 cmdLine.serial().printf("\r\n MAX11131.ReadAINcode");
whismanoid 0:3edb3708c8c5 4257 AINcode_print_value_externalClock(cmdLine, g_MAX11131_device.NumWords);
whismanoid 0:3edb3708c8c5 4258 // compare with mbed/Arduino AIN0-AIN3
whismanoid 0:3edb3708c8c5 4259 // MAX32625MBED.AIN4 = MAX11131.AIN0
whismanoid 0:3edb3708c8c5 4260 channelId = 0;
whismanoid 0:3edb3708c8c5 4261 value_u12 = g_MAX11131_device.AINcode[channelId];
whismanoid 0:3edb3708c8c5 4262 voltageV = g_MAX11131_device.VoltageOfCode(value_u12, channelId);
whismanoid 3:8913cb4a8b9f 4263 //
whismanoid 5:82037e281451 4264 // tinyTester.Wait_Output_Settling replaces wait_ms
whismanoid 3:8913cb4a8b9f 4265 tinyTester.Wait_Output_Settling();
whismanoid 5:82037e281451 4266 // tinyTester.AnalogIn0_Read_Expect_voltageV replaces SelfTest_AnalogInput_Expect_ch_V
whismanoid 3:8913cb4a8b9f 4267 tinyTester.err_threshold = 0.100;
whismanoid 3:8913cb4a8b9f 4268 tinyTester.AnalogIn0_Read_Expect_voltageV(voltageV);
whismanoid 3:8913cb4a8b9f 4269 //
whismanoid 0:3edb3708c8c5 4270 //
whismanoid 0:3edb3708c8c5 4271 cmdLine.serial().printf("\r\n");
whismanoid 0:3edb3708c8c5 4272 cmdLine.serial().printf("\r\n 3.4: Test SCAN_0100_StandardExternalClock");
whismanoid 0:3edb3708c8c5 4273 cmdLine.serial().printf("\r\n MAX11131.Init()");
whismanoid 0:3edb3708c8c5 4274 g_MAX11131_device.Init();
whismanoid 0:3edb3708c8c5 4275 // MAX11131 > 4
whismanoid 0:3edb3708c8c5 4276 // ScanStandardExternalClock ch=9 pm=0 id=1
whismanoid 0:3edb3708c8c5 4277 // ScanRead_nWords_chanID nWords=10
whismanoid 0:3edb3708c8c5 4278 // ch=0 xu=2964 = 0x0b94 = 1.8091V
whismanoid 0:3edb3708c8c5 4279 // ch=1 xu=2227 = 0x08b3 = 1.3593V
whismanoid 0:3edb3708c8c5 4280 // ch=2 xu=1570 = 0x0622 = 0.9583V
whismanoid 0:3edb3708c8c5 4281 // ch=3 xu=865 = 0x0361 = 0.5280V
whismanoid 0:3edb3708c8c5 4282 // ch=4 xu=630 = 0x0276 = 0.3845V
whismanoid 0:3edb3708c8c5 4283 // ch=5 xu=594 = 0x0252 = 0.3625V
whismanoid 0:3edb3708c8c5 4284 // ch=6 xu=461 = 0x01cd = 0.2814V
whismanoid 0:3edb3708c8c5 4285 // ch=7 xu=364 = 0x016c = 0.2222V
whismanoid 0:3edb3708c8c5 4286 // ch=8 xu=480 = 0x01e0 = 0.2930V
whismanoid 0:3edb3708c8c5 4287 // ch=9 xu=616 = 0x0268 = 0.3760V
whismanoid 0:3edb3708c8c5 4288 g_MAX11131_device.channelNumber_0_15 = 9;
whismanoid 0:3edb3708c8c5 4289 g_MAX11131_device.PowerManagement_0_2 = 0;
whismanoid 0:3edb3708c8c5 4290 g_MAX11131_device.chan_id_0_1 = 1;
whismanoid 0:3edb3708c8c5 4291 cmdLine.serial().printf("\r\n MAX11131.channelNumber_0_15=%d", g_MAX11131_device.channelNumber_0_15);
whismanoid 0:3edb3708c8c5 4292 cmdLine.serial().printf("\r\n MAX11131.PowerManagement_0_2=%d", g_MAX11131_device.PowerManagement_0_2);
whismanoid 0:3edb3708c8c5 4293 cmdLine.serial().printf("\r\n MAX11131.chan_id_0_1=%d", g_MAX11131_device.chan_id_0_1);
whismanoid 0:3edb3708c8c5 4294 g_MAX11131_device.NumWords = g_MAX11131_device.ScanStandardExternalClock();
whismanoid 0:3edb3708c8c5 4295 cmdLine.serial().printf("\r\n MAX11131.ScanStandardExternalClock -- NumWords = %d",
whismanoid 0:3edb3708c8c5 4296 g_MAX11131_device.NumWords);
whismanoid 0:3edb3708c8c5 4297 // Read raw ADC codes from device into AINcode[] and RAW_misoData16[]
whismanoid 0:3edb3708c8c5 4298 // @pre one of the MAX11311_Scan functions was called, setting g_MAX11131_device.NumWords
whismanoid 0:3edb3708c8c5 4299 g_MAX11131_device.ReadAINcode();
whismanoid 0:3edb3708c8c5 4300 cmdLine.serial().printf("\r\n MAX11131.ReadAINcode");
whismanoid 0:3edb3708c8c5 4301 // @post RAW_misoData16[index] contains the raw SPI Master-In,Slave-Out data
whismanoid 0:3edb3708c8c5 4302 // @post AINcode[NUM_CHANNELS] contains the latest readings in LSBs
whismanoid 5:82037e281451 4303 // expect g_MAX11131_device.NumWords == g_MAX11131_device.channelNumber_0_15 + 1;
whismanoid 5:82037e281451 4304 // expect RAW_misoData16[index] msnybble 0,1,2,3,...
whismanoid 0:3edb3708c8c5 4305 AINcode_print_value_externalClock(cmdLine, g_MAX11131_device.NumWords);
whismanoid 5:82037e281451 4306 // compare with mbed/Arduino AIN0-AIN3
whismanoid 0:3edb3708c8c5 4307 // MAX32625MBED.AIN4 = MAX11131.AIN0
whismanoid 0:3edb3708c8c5 4308 channelId = 0;
whismanoid 0:3edb3708c8c5 4309 value_u12 = g_MAX11131_device.AINcode[channelId];
whismanoid 0:3edb3708c8c5 4310 voltageV = g_MAX11131_device.VoltageOfCode(value_u12, channelId);
whismanoid 5:82037e281451 4311 // tinyTester.Wait_Output_Settling replaces wait_ms
whismanoid 3:8913cb4a8b9f 4312 tinyTester.Wait_Output_Settling();
whismanoid 5:82037e281451 4313 // tinyTester.AnalogIn0_Read_Expect_voltageV replaces SelfTest_AnalogInput_Expect_ch_V
whismanoid 3:8913cb4a8b9f 4314 tinyTester.err_threshold = 0.100;
whismanoid 3:8913cb4a8b9f 4315 tinyTester.AnalogIn0_Read_Expect_voltageV(voltageV);
whismanoid 5:82037e281451 4316 // compare MAX32625MBED.AIN5 = MAX11131.AIN1
whismanoid 0:3edb3708c8c5 4317 //channelId = 1;
whismanoid 0:3edb3708c8c5 4318 //value_u12 = g_MAX11131_device.AINcode[channelId];
whismanoid 0:3edb3708c8c5 4319 //voltageV = g_MAX11131_device.VoltageOfCode(value_u12, channelId);
whismanoid 0:3edb3708c8c5 4320 //SelfTest_AnalogInput_Expect_ch_V(cmdLine, 5, voltageV, 0.100);
whismanoid 0:3edb3708c8c5 4321 //
whismanoid 0:3edb3708c8c5 4322 #elif APPLICATION_MAX5171
whismanoid 0:3edb3708c8c5 4323
whismanoid 5:82037e281451 4324 // tinyTester.FunctionCall_Expect replaces SelfTest_DACCodeOfVoltage_Expect
whismanoid 0:3edb3708c8c5 4325 //
whismanoid 1:40369075c365 4326 // Note: ide.mbed.com does not support C++11 Lambda Expressions
whismanoid 1:40369075c365 4327 // -- see https://os.mbed.com/questions/82580/Is-there-solution-for-defining-of-interr/
whismanoid 0:3edb3708c8c5 4328 // define function under test using C++11 lambda expression [](){}
whismanoid 0:3edb3708c8c5 4329 // uint8_t MAX5171::Init(void)
whismanoid 2:b3a8a0ca0a94 4330 //uint8_t (*fn_MAX5171_Init)() = [](){ return g_MAX5171_device.Init(); };
whismanoid 0:3edb3708c8c5 4331 //
whismanoid 0:3edb3708c8c5 4332 // define function under test using C++11 lambda expression [](){}
whismanoid 0:3edb3708c8c5 4333 // uint16_t MAX5171::DACCodeOfVoltage(double voltageV)
whismanoid 2:b3a8a0ca0a94 4334 //uint16_t (*fn_MAX5171_DACCodeOfVoltage)(double) = [](double voltageV){ return g_MAX5171_device.DACCodeOfVoltage(voltageV); };
whismanoid 0:3edb3708c8c5 4335 //
whismanoid 0:3edb3708c8c5 4336 // define function under test using C++11 lambda expression [](){}
whismanoid 0:3edb3708c8c5 4337 // double MAX5171::VoltageOfCode(uint16_t value_u14)
whismanoid 2:b3a8a0ca0a94 4338 //double (*fn_MAX5171_VoltageOfCode)(uint16_t) = [](uint16_t value_u14){ return g_MAX5171_device.VoltageOfCode(value_u14); };
whismanoid 0:3edb3708c8c5 4339 //
whismanoid 0:3edb3708c8c5 4340 // define function under test using C++11 lambda expression [](){}
whismanoid 0:3edb3708c8c5 4341 // uint8_t MAX5171::CODE_LOAD(uint16_t dacCodeLsbs)
whismanoid 2:b3a8a0ca0a94 4342 //uint8_t (*fn_MAX5171_CODE_LOAD)(uint16_t dacCodeLsbs) = [](uint16_t dacCodeLsbs){ return g_MAX5171_device.CODE_LOAD(dacCodeLsbs); };
whismanoid 0:3edb3708c8c5 4343 //
whismanoid 0:3edb3708c8c5 4344 //double one_LSB = (g_MAX5171_device.VRef / 16383); // 14-bit DAC FS
whismanoid 0:3edb3708c8c5 4345 tinyTester.err_threshold = (g_MAX5171_device.VRef / 16383); // 14-bit DAC FS
whismanoid 5:82037e281451 4346 // tinyTester.Wait_Output_Settling replaces wait_ms
whismanoid 0:3edb3708c8c5 4347 tinyTester.settle_time_msec = 250;
whismanoid 0:3edb3708c8c5 4348
whismanoid 0:3edb3708c8c5 4349 g_MAX5171_device.VRef = 2.500; // MAX5171 14-bit LSB = 0.00015V
whismanoid 0:3edb3708c8c5 4350 SelfTest_print_Vref(cmdLine);
whismanoid 0:3edb3708c8c5 4351 //
whismanoid 5:82037e281451 4352 // tinyTester.FunctionCall_Expect replaces SelfTest_DACCodeOfVoltage_Expect
whismanoid 0:3edb3708c8c5 4353 tinyTester.FunctionCall_Expect("MAX5171.DACCodeOfVoltage", fn_MAX5171_DACCodeOfVoltage, 2.499847412109375, 0x3FFF);
whismanoid 0:3edb3708c8c5 4354 tinyTester.FunctionCall_Expect("MAX5171.DACCodeOfVoltage", fn_MAX5171_DACCodeOfVoltage, 2.49969482421875, 0x3FFE);
whismanoid 0:3edb3708c8c5 4355 tinyTester.FunctionCall_Expect("MAX5171.DACCodeOfVoltage", fn_MAX5171_DACCodeOfVoltage, 2.499542236328125, 0x3FFD);
whismanoid 0:3edb3708c8c5 4356 tinyTester.FunctionCall_Expect("MAX5171.DACCodeOfVoltage", fn_MAX5171_DACCodeOfVoltage, 2.4993896484375, 0x3FFC);
whismanoid 0:3edb3708c8c5 4357 //
whismanoid 0:3edb3708c8c5 4358 tinyTester.FunctionCall_Expect("MAX5171.DACCodeOfVoltage", fn_MAX5171_DACCodeOfVoltage, 1.250152587890625, 0x2001);
whismanoid 0:3edb3708c8c5 4359 tinyTester.FunctionCall_Expect("MAX5171.DACCodeOfVoltage", fn_MAX5171_DACCodeOfVoltage, 1.25, 0x2000);
whismanoid 0:3edb3708c8c5 4360 tinyTester.FunctionCall_Expect("MAX5171.DACCodeOfVoltage", fn_MAX5171_DACCodeOfVoltage, 1.249847412109375, 0x1FFF);
whismanoid 0:3edb3708c8c5 4361 tinyTester.FunctionCall_Expect("MAX5171.DACCodeOfVoltage", fn_MAX5171_DACCodeOfVoltage, 1.24969482421875, 0x1FFE);
whismanoid 0:3edb3708c8c5 4362 //
whismanoid 0:3edb3708c8c5 4363 tinyTester.FunctionCall_Expect("MAX5171.DACCodeOfVoltage", fn_MAX5171_DACCodeOfVoltage, 0.000457763671875, 0x0003);
whismanoid 0:3edb3708c8c5 4364 tinyTester.FunctionCall_Expect("MAX5171.DACCodeOfVoltage", fn_MAX5171_DACCodeOfVoltage, 0.00030517578125, 0x0002);
whismanoid 0:3edb3708c8c5 4365 tinyTester.FunctionCall_Expect("MAX5171.DACCodeOfVoltage", fn_MAX5171_DACCodeOfVoltage, 0.000152587890625, 0x0001);
whismanoid 0:3edb3708c8c5 4366 tinyTester.FunctionCall_Expect("MAX5171.DACCodeOfVoltage", fn_MAX5171_DACCodeOfVoltage, 0.00000, 0x0000);
whismanoid 0:3edb3708c8c5 4367 //
whismanoid 5:82037e281451 4368 // tinyTester.FunctionCall_Expect replaces SelfTest_VoltageOfCode_Expect
whismanoid 0:3edb3708c8c5 4369 tinyTester.FunctionCall_Expect("MAX5171.VoltageOfCode", fn_MAX5171_VoltageOfCode, 0x3FFF, 2.499847412109375);
whismanoid 0:3edb3708c8c5 4370 tinyTester.FunctionCall_Expect("MAX5171.VoltageOfCode", fn_MAX5171_VoltageOfCode, 0x3FFE, 2.49969482421875);
whismanoid 0:3edb3708c8c5 4371 tinyTester.FunctionCall_Expect("MAX5171.VoltageOfCode", fn_MAX5171_VoltageOfCode, 0x3FFD, 2.499542236328125);
whismanoid 0:3edb3708c8c5 4372 tinyTester.FunctionCall_Expect("MAX5171.VoltageOfCode", fn_MAX5171_VoltageOfCode, 0x3FFC, 2.4993896484375);
whismanoid 0:3edb3708c8c5 4373 //
whismanoid 0:3edb3708c8c5 4374 tinyTester.FunctionCall_Expect("MAX5171.VoltageOfCode", fn_MAX5171_VoltageOfCode, 0x2001, 1.250152587890625);
whismanoid 0:3edb3708c8c5 4375 tinyTester.FunctionCall_Expect("MAX5171.VoltageOfCode", fn_MAX5171_VoltageOfCode, 0x2000, 1.25);
whismanoid 0:3edb3708c8c5 4376 tinyTester.FunctionCall_Expect("MAX5171.VoltageOfCode", fn_MAX5171_VoltageOfCode, 0x1FFF, 1.249847412109375);
whismanoid 0:3edb3708c8c5 4377 tinyTester.FunctionCall_Expect("MAX5171.VoltageOfCode", fn_MAX5171_VoltageOfCode, 0x1FFE, 1.24969482421875);
whismanoid 0:3edb3708c8c5 4378 //
whismanoid 0:3edb3708c8c5 4379 tinyTester.FunctionCall_Expect("MAX5171.VoltageOfCode", fn_MAX5171_VoltageOfCode, 0x0003, 0.000457763671875);
whismanoid 0:3edb3708c8c5 4380 tinyTester.FunctionCall_Expect("MAX5171.VoltageOfCode", fn_MAX5171_VoltageOfCode, 0x0002, 0.00030517578125);
whismanoid 0:3edb3708c8c5 4381 tinyTester.FunctionCall_Expect("MAX5171.VoltageOfCode", fn_MAX5171_VoltageOfCode, 0x0001, 0.000152587890625);
whismanoid 0:3edb3708c8c5 4382 tinyTester.FunctionCall_Expect("MAX5171.VoltageOfCode", fn_MAX5171_VoltageOfCode, 0x0000, 0.00000);
whismanoid 0:3edb3708c8c5 4383 //
whismanoid 0:3edb3708c8c5 4384 // Device Testing: DAC commands, verify using on-board ADC inputs
whismanoid 0:3edb3708c8c5 4385 //
whismanoid 0:3edb3708c8c5 4386 cmdLine.serial().printf("\r\n MAX5171.Init()");
whismanoid 0:3edb3708c8c5 4387 g_MAX5171_device.Init();
whismanoid 0:3edb3708c8c5 4388 //
whismanoid 0:3edb3708c8c5 4389 tinyTester.err_threshold = 0.030; // 30mV
whismanoid 0:3edb3708c8c5 4390 uint16_t code = 0x3FFF;
whismanoid 0:3edb3708c8c5 4391 //~ double voltageV = 0.5;
whismanoid 0:3edb3708c8c5 4392 //
whismanoid 0:3edb3708c8c5 4393 cmdLine.serial().printf("\r\n MAX5171.CODE_LOAD code=%d", code);
whismanoid 0:3edb3708c8c5 4394 g_MAX5171_device.CODE_LOAD(code);
whismanoid 5:82037e281451 4395 // tinyTester.Wait_Output_Settling replaces wait_ms
whismanoid 0:3edb3708c8c5 4396 tinyTester.Wait_Output_Settling();
whismanoid 5:82037e281451 4397 // tinyTester.AnalogIn0_Read_Expect_voltageV replaces SelfTest_AnalogInput_Expect_ch_V
whismanoid 0:3edb3708c8c5 4398 tinyTester.AnalogIn0_Read_Expect_voltageV(2.500);
whismanoid 0:3edb3708c8c5 4399 //
whismanoid 0:3edb3708c8c5 4400 code = 0x0000;
whismanoid 0:3edb3708c8c5 4401 cmdLine.serial().printf("\r\n MAX5171.CODE_LOAD code=%d", code);
whismanoid 0:3edb3708c8c5 4402 g_MAX5171_device.CODE_LOAD(code);
whismanoid 5:82037e281451 4403 // tinyTester.Wait_Output_Settling replaces wait_ms
whismanoid 0:3edb3708c8c5 4404 tinyTester.Wait_Output_Settling();
whismanoid 5:82037e281451 4405 // tinyTester.AnalogIn0_Read_Expect_voltageV replaces SelfTest_AnalogInput_Expect_ch_V
whismanoid 0:3edb3708c8c5 4406 tinyTester.AnalogIn0_Read_Expect_voltageV(0.0000);
whismanoid 0:3edb3708c8c5 4407 //
whismanoid 0:3edb3708c8c5 4408 code = 0x1FFF;
whismanoid 0:3edb3708c8c5 4409 cmdLine.serial().printf("\r\n MAX5171.CODE_LOAD code=%d", code);
whismanoid 0:3edb3708c8c5 4410 g_MAX5171_device.CODE_LOAD(code);
whismanoid 5:82037e281451 4411 // tinyTester.Wait_Output_Settling replaces wait_ms
whismanoid 0:3edb3708c8c5 4412 tinyTester.Wait_Output_Settling();
whismanoid 5:82037e281451 4413 // tinyTester.AnalogIn0_Read_Expect_voltageV replaces SelfTest_AnalogInput_Expect_ch_V
whismanoid 0:3edb3708c8c5 4414 tinyTester.AnalogIn0_Read_Expect_voltageV(1.2500);
whismanoid 0:3edb3708c8c5 4415 //
whismanoid 0:3edb3708c8c5 4416 // test UPO User Programmable Output, verify using digital input D2
whismanoid 0:3edb3708c8c5 4417 //
whismanoid 0:3edb3708c8c5 4418 cmdLine.serial().printf("\r\n MAX5171.UPO_HIGH");
whismanoid 0:3edb3708c8c5 4419 g_MAX5171_device.UPO_HIGH();
whismanoid 0:3edb3708c8c5 4420 tinyTester.Wait_Output_Settling();
whismanoid 5:82037e281451 4421 // tinyTester.DigitalIn_Read_Expect_WarnOnly replaces SelfTest_Expect_Input_UPO_pin
whismanoid 0:3edb3708c8c5 4422 tinyTester.DigitalIn_Read_Expect_WarnOnly(UPO_pin, "UPO", 1, "UPO_pin is high after MAX5171 UPO_HIGH command");
whismanoid 0:3edb3708c8c5 4423 //
whismanoid 0:3edb3708c8c5 4424 cmdLine.serial().printf("\r\n MAX5171.UPO_LOW");
whismanoid 0:3edb3708c8c5 4425 g_MAX5171_device.UPO_LOW();
whismanoid 0:3edb3708c8c5 4426 tinyTester.Wait_Output_Settling();
whismanoid 5:82037e281451 4427 // tinyTester.DigitalIn_Read_Expect_WarnOnly replaces SelfTest_Expect_Input_UPO_pin
whismanoid 0:3edb3708c8c5 4428 tinyTester.DigitalIn_Read_Expect_WarnOnly(UPO_pin, "UPO", 0, "UPO_pin is low after MAX5171 UPO_LOW command");
whismanoid 0:3edb3708c8c5 4429 //
whismanoid 0:3edb3708c8c5 4430 cmdLine.serial().printf("\r\n MAX5171.UPO_HIGH");
whismanoid 0:3edb3708c8c5 4431 g_MAX5171_device.UPO_HIGH();
whismanoid 0:3edb3708c8c5 4432 tinyTester.Wait_Output_Settling(); // wait_ms(100); // delay
whismanoid 5:82037e281451 4433 // tinyTester.DigitalIn_Read_Expect_WarnOnly replaces SelfTest_Expect_Input_UPO_pin
whismanoid 0:3edb3708c8c5 4434 tinyTester.DigitalIn_Read_Expect_WarnOnly(UPO_pin, "UPO", 1, "UPO_pin is high after MAX5171 UPO_HIGH command");
whismanoid 0:3edb3708c8c5 4435 //
whismanoid 0:3edb3708c8c5 4436 #elif APPLICATION_MAX11410
whismanoid 0:3edb3708c8c5 4437 //
whismanoid 0:3edb3708c8c5 4438 // TODO: placeholder for self-test functions
whismanoid 0:3edb3708c8c5 4439 SelfTest_FAIL(cmdLine);
whismanoid 0:3edb3708c8c5 4440 cmdLine.serial().printf("test program not implemented yet");
whismanoid 0:3edb3708c8c5 4441 //
whismanoid 0:3edb3708c8c5 4442 #elif APPLICATION_MAX12345
whismanoid 0:3edb3708c8c5 4443 //
whismanoid 0:3edb3708c8c5 4444 // TODO: placeholder for self-test functions
whismanoid 0:3edb3708c8c5 4445 SelfTest_FAIL(cmdLine);
whismanoid 0:3edb3708c8c5 4446 cmdLine.serial().printf("test program not implemented yet");
whismanoid 0:3edb3708c8c5 4447 //
whismanoid 0:3edb3708c8c5 4448 #else // APPLICATION_MAX5715
whismanoid 0:3edb3708c8c5 4449 // TODO: placeholder for self-test functions
whismanoid 0:3edb3708c8c5 4450 #endif // APPLICATION_MAX5715
whismanoid 0:3edb3708c8c5 4451 //
whismanoid 0:3edb3708c8c5 4452 #if 0
whismanoid 0:3edb3708c8c5 4453 // Test of the pass/fail report mechanism
whismanoid 0:3edb3708c8c5 4454 SelfTest_FAIL(cmdLine);
whismanoid 0:3edb3708c8c5 4455 cmdLine.serial().printf("injecting one false failure for test reporting");
whismanoid 0:3edb3708c8c5 4456 #endif
whismanoid 0:3edb3708c8c5 4457 //
whismanoid 0:3edb3708c8c5 4458 // Report number of pass and number of fail test results
whismanoid 0:3edb3708c8c5 4459 tinyTester.Report_Summary();
whismanoid 0:3edb3708c8c5 4460 #if USE_LEDS
whismanoid 0:3edb3708c8c5 4461 if (tinyTester.nFail == 0) {
whismanoid 0:3edb3708c8c5 4462 rgb_led.green(); // diagnostic rbg led GREEN
whismanoid 0:3edb3708c8c5 4463 }
whismanoid 0:3edb3708c8c5 4464 else {
whismanoid 0:3edb3708c8c5 4465 rgb_led.red(); // diagnostic rbg led RED
whismanoid 0:3edb3708c8c5 4466 }
whismanoid 0:3edb3708c8c5 4467 #endif // USE_LEDS
whismanoid 0:3edb3708c8c5 4468 }
whismanoid 0:3edb3708c8c5 4469
whismanoid 0:3edb3708c8c5 4470
whismanoid 0:3edb3708c8c5 4471 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 4472 void main_menu_status(CmdLine & cmdLine)
whismanoid 0:3edb3708c8c5 4473 {
whismanoid 0:3edb3708c8c5 4474 cmdLine.serial().printf("\r\nMain menu");
whismanoid 0:3edb3708c8c5 4475 #if APPLICATION_MAX5715 // main_menu_status banner
whismanoid 0:3edb3708c8c5 4476 cmdLine.serial().printf(" MAX5715 12-bit 4-ch SPI VOUT DAC");
whismanoid 0:3edb3708c8c5 4477 #elif APPLICATION_MAX11131 // main_menu_status banner
whismanoid 0:3edb3708c8c5 4478 cmdLine.serial().printf(" MAX11131 12-bit 3MSps 16-ch ADC");
whismanoid 0:3edb3708c8c5 4479 #elif APPLICATION_MAX5171 // main_menu_status banner
whismanoid 0:3edb3708c8c5 4480 cmdLine.serial().printf(" MAX5171 14-bit Force/Sense VOUT DAC");
whismanoid 0:3edb3708c8c5 4481 #elif APPLICATION_MAX11410 // main_menu_status banner
whismanoid 0:3edb3708c8c5 4482 cmdLine.serial().printf(" MAX11410 24-bit 1.9ksps Delta-Sigma ADC");
whismanoid 0:3edb3708c8c5 4483 #elif APPLICATION_MAX12345 // main_menu_status banner
whismanoid 0:3edb3708c8c5 4484 cmdLine.serial().printf(" MAX12345");
whismanoid 0:3edb3708c8c5 4485 #else
whismanoid 0:3edb3708c8c5 4486 //cmdLine.serial().printf(" ");
whismanoid 0:3edb3708c8c5 4487 #endif
whismanoid 0:3edb3708c8c5 4488 cmdLine.serial().printf(" %s", TARGET_NAME);
whismanoid 0:3edb3708c8c5 4489 if (cmdLine.nameStr())
whismanoid 0:3edb3708c8c5 4490 {
whismanoid 0:3edb3708c8c5 4491 cmdLine.serial().printf(" [%s]", cmdLine.nameStr());
whismanoid 0:3edb3708c8c5 4492 }
whismanoid 0:3edb3708c8c5 4493 #if USE_COMMAND_BUFFER
whismanoid 0:3edb3708c8c5 4494 //cmdLine.serial().printf(" [USE_COMMAND_BUFFER]");
whismanoid 0:3edb3708c8c5 4495 #endif
whismanoid 0:3edb3708c8c5 4496 #if HAS_BUTTON1_DEMO_INTERRUPT
whismanoid 0:3edb3708c8c5 4497 cmdLine.serial().printf(" [Button1=DemoConfig1]");
whismanoid 0:3edb3708c8c5 4498 #endif
whismanoid 0:3edb3708c8c5 4499 #if HAS_BUTTON2_DEMO_INTERRUPT
whismanoid 0:3edb3708c8c5 4500 cmdLine.serial().printf(" [Button2=DemoConfig2]");
whismanoid 0:3edb3708c8c5 4501 #endif
whismanoid 0:3edb3708c8c5 4502 #if HAS_BUTTON1_DEMO
whismanoid 0:3edb3708c8c5 4503 // print BUTTON1 status
whismanoid 0:3edb3708c8c5 4504 cmdLine.serial().printf("\r\n BUTTON1 = %d", button1.read());
whismanoid 0:3edb3708c8c5 4505 #endif
whismanoid 0:3edb3708c8c5 4506 #if HAS_BUTTON2_DEMO
whismanoid 0:3edb3708c8c5 4507 // print BUTTON1 status
whismanoid 0:3edb3708c8c5 4508 cmdLine.serial().printf("\r\n BUTTON2 = %d", button2.read());
whismanoid 0:3edb3708c8c5 4509 #endif
whismanoid 0:3edb3708c8c5 4510 cmdLine.serial().printf("\r\n ? -- help");
whismanoid 0:3edb3708c8c5 4511 }
whismanoid 0:3edb3708c8c5 4512
whismanoid 0:3edb3708c8c5 4513 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 4514 void main_menu_help(CmdLine & cmdLine)
whismanoid 0:3edb3708c8c5 4515 {
whismanoid 0:3edb3708c8c5 4516 // ? -- help
whismanoid 0:3edb3708c8c5 4517 //~ cmdLine.serial().printf("\r\nMenu:");
whismanoid 0:3edb3708c8c5 4518 cmdLine.serial().printf("\r\n # -- lines beginning with # are comments");
whismanoid 0:3edb3708c8c5 4519 cmdLine.serial().printf("\r\n . -- SelfTest");
whismanoid 0:3edb3708c8c5 4520 //cmdLine.serial().printf("\r\n ! -- Initial Configuration");
whismanoid 0:3edb3708c8c5 4521 //
whismanoid 0:3edb3708c8c5 4522 // % standardize diagnostic commands
whismanoid 0:3edb3708c8c5 4523 // %Hpin -- digital output high
whismanoid 0:3edb3708c8c5 4524 // %Lpin -- digital output low
whismanoid 0:3edb3708c8c5 4525 // %?pin -- digital input
whismanoid 0:3edb3708c8c5 4526 // %A %Apin -- analog input
whismanoid 0:3edb3708c8c5 4527 // %Ppin df=xx -- pwm output
whismanoid 0:3edb3708c8c5 4528 // %Wpin -- measure high pulsewidth input in usec
whismanoid 0:3edb3708c8c5 4529 // %wpin -- measure low pulsewidth input in usec
whismanoid 0:3edb3708c8c5 4530 // %I... -- I2C diagnostics
whismanoid 0:3edb3708c8c5 4531 // %IP -- I2C probe
whismanoid 0:3edb3708c8c5 4532 // %IC scl=100khz ADDR=? -- I2C configure
whismanoid 0:3edb3708c8c5 4533 // %IW ADDR=? cmd=? data,data,data -- write
whismanoid 0:3edb3708c8c5 4534 // %IR ADDR=? RD=? -- read
whismanoid 0:3edb3708c8c5 4535 // %I^ cmd=? -- i2c_smbus_read_word_data
whismanoid 0:3edb3708c8c5 4536 // %S... -- SPI diagnostics
whismanoid 0:3edb3708c8c5 4537 // %SC sclk=1Mhz -- SPI configure
whismanoid 0:3edb3708c8c5 4538 // %SW -- write (write and read)
whismanoid 0:3edb3708c8c5 4539 // %SR -- read (alias for %SW because SPI always write and read)
whismanoid 0:3edb3708c8c5 4540 // A-Z,a-z,0-9 reserved for application use
whismanoid 0:3edb3708c8c5 4541 //
whismanoid 0:3edb3708c8c5 4542 #if HAS_digitalInOuts
whismanoid 0:3edb3708c8c5 4543 // %Hpin -- digital output high
whismanoid 0:3edb3708c8c5 4544 // %Lpin -- digital output low
whismanoid 0:3edb3708c8c5 4545 // %?pin -- digital input
whismanoid 0:3edb3708c8c5 4546 cmdLine.serial().printf("\r\n %%Hn {pin:");
whismanoid 0:3edb3708c8c5 4547 list_digitalInOutPins(cmdLine.serial());
whismanoid 0:3edb3708c8c5 4548 cmdLine.serial().printf("} -- High Output");
whismanoid 0:3edb3708c8c5 4549 cmdLine.serial().printf("\r\n %%Ln {pin:");
whismanoid 0:3edb3708c8c5 4550 list_digitalInOutPins(cmdLine.serial());
whismanoid 0:3edb3708c8c5 4551 cmdLine.serial().printf("} -- Low Output");
whismanoid 0:3edb3708c8c5 4552 cmdLine.serial().printf("\r\n %%?n {pin:");
whismanoid 0:3edb3708c8c5 4553 list_digitalInOutPins(cmdLine.serial());
whismanoid 0:3edb3708c8c5 4554 cmdLine.serial().printf("} -- Input");
whismanoid 0:3edb3708c8c5 4555 #endif
whismanoid 0:3edb3708c8c5 4556
whismanoid 0:3edb3708c8c5 4557 #if HAS_analogIns
whismanoid 0:3edb3708c8c5 4558 // Menu A) analogRead A0..7
whismanoid 0:3edb3708c8c5 4559 // %A %Apin -- analog input
whismanoid 0:3edb3708c8c5 4560 // analogRead(pinIndex) // analog input pins A0, A1, A2, A3, A4, A5; float voltage = analogRead(A0) * (5.0 / 1023.0)
whismanoid 0:3edb3708c8c5 4561 cmdLine.serial().printf("\r\n %%A -- analogRead");
whismanoid 0:3edb3708c8c5 4562 #endif
whismanoid 0:3edb3708c8c5 4563
whismanoid 0:3edb3708c8c5 4564 #if HAS_SPI2_MAX541
whismanoid 0:3edb3708c8c5 4565 // TODO1: MAX541 max541(spi2_max541, spi2_max541_cs);
whismanoid 0:3edb3708c8c5 4566 cmdLine.serial().printf("\r\n %%D -- DAC output MAX541 (SPI2)");
whismanoid 0:3edb3708c8c5 4567 #endif
whismanoid 0:3edb3708c8c5 4568
whismanoid 0:3edb3708c8c5 4569 #if HAS_pwmDrivers
whismanoid 0:3edb3708c8c5 4570 // Menu P) PWM D3|5|6|9|10|11, Output 0..255
whismanoid 0:3edb3708c8c5 4571 // %Ppin df=xx -- pwm output
whismanoid 0:3edb3708c8c5 4572 cmdLine.serial().printf("\r\n %%P {High|Low|.|>|<|S|F} 0..255, {pin: *");
whismanoid 0:3edb3708c8c5 4573 // analogWrite(analogOutPin, outputValue_0_255) // PWM digital output 0..255: analogWrite works on digital pins 3, 5, 6, 9, 10, and 11. Frequency is 490 Hz except pins 5 and 6 are 980 Hz.
whismanoid 0:3edb3708c8c5 4574 //cmdLine.serial().printf("\r\n P) pwmDriver {High|Low|.|>|<|S|F} {pin: *");
whismanoid 0:3edb3708c8c5 4575 list_pwmDriverPins(cmdLine.serial());
whismanoid 0:3edb3708c8c5 4576 cmdLine.serial().printf("} -- PWM Output");
whismanoid 0:3edb3708c8c5 4577 #endif
whismanoid 0:3edb3708c8c5 4578
whismanoid 0:3edb3708c8c5 4579 #if HAS_I2C // SUPPORT_I2C
whismanoid 0:3edb3708c8c5 4580 // TODO: support I2C HAS_I2C // SUPPORT_I2C
whismanoid 0:3edb3708c8c5 4581 // VERIFY: I2C utility commands SUPPORT_I2C
whismanoid 0:3edb3708c8c5 4582 // VERIFY: report g_I2C_SCL_Hz = (F_CPU / ((TWBR * 2) + 16)) from last Wire_Sr.setClock(I2C_SCL_Hz);
whismanoid 0:3edb3708c8c5 4583 // %I... -- I2C diagnostics
whismanoid 0:3edb3708c8c5 4584 // %IP -- I2C probe
whismanoid 0:3edb3708c8c5 4585 // %IC scl=100khz ADDR=? -- I2C configure
whismanoid 0:3edb3708c8c5 4586 // %IW byte byte ... byte RD=? ADDR=0x -- write
whismanoid 0:3edb3708c8c5 4587 // %IR ADDR=? RD=? -- read
whismanoid 0:3edb3708c8c5 4588 // %I^ cmd=? -- i2c_smbus_read_word_data
whismanoid 0:3edb3708c8c5 4589 //g_I2C_SCL_Hz = (F_CPU / ((TWBR * 2) + 16)); // 'F_CPU' 'TWBR' not declared in this scope
whismanoid 0:3edb3708c8c5 4590 cmdLine.serial().printf("\r\n %%IC ADDR=0x%2.2x=(0x%2.2x>>1) SCL=%d=%1.3fkHz -- I2C config",
whismanoid 0:3edb3708c8c5 4591 g_I2C_deviceAddress7, (g_I2C_deviceAddress7 << 1), g_I2C_SCL_Hz,
whismanoid 0:3edb3708c8c5 4592 (g_I2C_SCL_Hz / 1000.));
whismanoid 0:3edb3708c8c5 4593 cmdLine.serial().printf("\r\n %%IW byte byte ... byte RD=? ADDR=0x%2.2x -- I2C write/read",
whismanoid 0:3edb3708c8c5 4594 g_I2C_deviceAddress7);
whismanoid 0:3edb3708c8c5 4595 //
whismanoid 0:3edb3708c8c5 4596 #if SUPPORT_I2C
whismanoid 0:3edb3708c8c5 4597 // Menu ^ cmd=?) i2c_smbus_read_word_data
whismanoid 0:3edb3708c8c5 4598 cmdLine.serial().printf("\r\n %%I^ cmd=? -- i2c_smbus_read_word_data");
whismanoid 0:3edb3708c8c5 4599 // test low-level I2C i2c_smbus_read_word_data
whismanoid 0:3edb3708c8c5 4600 #endif // SUPPORT_I2C
whismanoid 0:3edb3708c8c5 4601 //cmdLine.serial().printf(" H) Hunt for attached I2C devices");
whismanoid 0:3edb3708c8c5 4602 cmdLine.serial().printf("\r\n %%IP -- I2C Probe for attached devices");
whismanoid 0:3edb3708c8c5 4603 // cmdLine.serial().printf(" s) search i2c address");
whismanoid 0:3edb3708c8c5 4604 #endif // SUPPORT_I2C
whismanoid 0:3edb3708c8c5 4605
whismanoid 0:3edb3708c8c5 4606 #if HAS_SPI // SUPPORT_SPI
whismanoid 0:3edb3708c8c5 4607 // TODO: support SPI HAS_SPI // SUPPORT_SPI
whismanoid 0:3edb3708c8c5 4608 // SPI test command S (mosiData)+
whismanoid 0:3edb3708c8c5 4609 // %S... -- SPI diagnostics
whismanoid 0:3edb3708c8c5 4610 // %SC sclk=1Mhz -- SPI configure
whismanoid 0:3edb3708c8c5 4611 // %SW -- write (write and read)
whismanoid 0:3edb3708c8c5 4612 // %SR -- read (alias for %SW because SPI always write and read)
whismanoid 0:3edb3708c8c5 4613 // spi.format(8,0); // int bits_must_be_8, int mode=0_3 CPOL=0,CPHA=0 rising edge (initial default)
whismanoid 0:3edb3708c8c5 4614 // spi.format(8,1); // int bits_must_be_8, int mode=0_3 CPOL=0,CPHA=1 falling edge (initial default)
whismanoid 0:3edb3708c8c5 4615 // spi.format(8,2); // int bits_must_be_8, int mode=0_3 CPOL=1,CPHA=0 falling edge (initial default)
whismanoid 0:3edb3708c8c5 4616 // spi.format(8,3); // int bits_must_be_8, int mode=0_3 CPOL=1,CPHA=1 rising edge (initial default)
whismanoid 0:3edb3708c8c5 4617 // spi.frequency(1000000); // int SCLK_Hz=1000000 = 1MHz (initial default)
whismanoid 0:3edb3708c8c5 4618 // mode | POL PHA
whismanoid 0:3edb3708c8c5 4619 // -----+--------
whismanoid 0:3edb3708c8c5 4620 // 0 | 0 0
whismanoid 0:3edb3708c8c5 4621 // 1 | 0 1
whismanoid 0:3edb3708c8c5 4622 // 2 | 1 0
whismanoid 0:3edb3708c8c5 4623 // 3 | 1 1
whismanoid 0:3edb3708c8c5 4624 //cmdLine.serial().printf(" S) SPI mosi,mosi,...mosi hex bytes SCLK=1000000 CPOL=0 CPHA=0");
whismanoid 0:3edb3708c8c5 4625 // fixed: mbed-os-5.11: [Warning] format '%d' expects argument of type 'int', but argument 3 has type 'uint32_t {aka long unsigned int}' [-Wformat=]
whismanoid 0:3edb3708c8c5 4626 cmdLine.serial().printf("\r\n %%SC SCLK=%ld=%1.3fMHz CPOL=%d CPHA=%d -- SPI config",
whismanoid 0:3edb3708c8c5 4627 g_SPI_SCLK_Hz, (g_SPI_SCLK_Hz / 1000000.),
whismanoid 0:3edb3708c8c5 4628 ((g_SPI_dataMode & SPI_MODE2) ? 1 : 0),
whismanoid 0:3edb3708c8c5 4629 ((g_SPI_dataMode & SPI_MODE1) ? 1 : 0));
whismanoid 0:3edb3708c8c5 4630 cmdLine.serial().printf("\r\n %%SW mosi,mosi,...mosi -- SPI write hex bytes");
whismanoid 0:3edb3708c8c5 4631 // VERIFY: parse new SPI settings parse_strCommandArgs() SCLK=1000000 CPOL=0 CPHA=0
whismanoid 0:3edb3708c8c5 4632 #endif // SUPPORT_SPI
whismanoid 0:3edb3708c8c5 4633 //
whismanoid 0:3edb3708c8c5 4634 // Application-specific commands (help text) here
whismanoid 0:3edb3708c8c5 4635 //
whismanoid 0:3edb3708c8c5 4636 #if APPLICATION_ArduinoPinsMonitor
whismanoid 0:3edb3708c8c5 4637 # if APPLICATION_MAX5715 // main_menu_help
whismanoid 0:3edb3708c8c5 4638 # elif APPLICATION_MAX11131 // main_menu_help
whismanoid 0:3edb3708c8c5 4639 # elif APPLICATION_MAX5171 // main_menu_help
whismanoid 0:3edb3708c8c5 4640 # elif APPLICATION_MAX11410 // main_menu_help
whismanoid 0:3edb3708c8c5 4641 # elif APPLICATION_MAX12345 // main_menu_help
whismanoid 0:3edb3708c8c5 4642 # else
whismanoid 0:3edb3708c8c5 4643 cmdLine.serial().printf("\r\n A-Z,a-z,0-9 -- reserved for application use"); // ArduinoPinsMonitor
whismanoid 0:3edb3708c8c5 4644 # endif
whismanoid 0:3edb3708c8c5 4645 #endif // APPLICATION_ArduinoPinsMonitor
whismanoid 0:3edb3708c8c5 4646 //
whismanoid 0:3edb3708c8c5 4647 #if APPLICATION_MAX5715 // main_menu_help
whismanoid 0:3edb3708c8c5 4648 cmdLine.serial().printf("\r\n 0 ch=? code=? -- CODEn");
whismanoid 0:3edb3708c8c5 4649 cmdLine.serial().printf("\r\n 1 ch=? -- LOADn");
whismanoid 0:3edb3708c8c5 4650 cmdLine.serial().printf("\r\n 2 ch=? code=? -- CODEnLOADall");
whismanoid 0:3edb3708c8c5 4651 cmdLine.serial().printf("\r\n 3 ch=? code=? -- CODEnLOADn");
whismanoid 0:3edb3708c8c5 4652 cmdLine.serial().printf("\r\n 40 ch=? -- POWERn_Normal");
whismanoid 0:3edb3708c8c5 4653 cmdLine.serial().printf("\r\n 41 ch=? -- POWERn_PD1k");
whismanoid 0:3edb3708c8c5 4654 cmdLine.serial().printf("\r\n 42 ch=? -- POWERn_PD100k");
whismanoid 0:3edb3708c8c5 4655 cmdLine.serial().printf("\r\n 43 ch=? -- POWERn_PDHiZ");
whismanoid 0:3edb3708c8c5 4656 cmdLine.serial().printf("\r\n 50 -- SW_CLEAR");
whismanoid 0:3edb3708c8c5 4657 cmdLine.serial().printf("\r\n 51 -- SW_RESET");
whismanoid 0:3edb3708c8c5 4658 cmdLine.serial().printf("\r\n 60 ch=? -- CONFIGn_LATCHED");
whismanoid 0:3edb3708c8c5 4659 cmdLine.serial().printf("\r\n 61 ch=? -- CONFIGn_TRANSPARENT");
whismanoid 0:3edb3708c8c5 4660 cmdLine.serial().printf("\r\n 68 -- CONFIGall_LATCHED");
whismanoid 0:3edb3708c8c5 4661 cmdLine.serial().printf("\r\n 69 -- CONFIGall_TRANSPARENT");
whismanoid 0:3edb3708c8c5 4662 cmdLine.serial().printf("\r\n 70 -- REF_EXT");
whismanoid 0:3edb3708c8c5 4663 cmdLine.serial().printf("\r\n 71 -- REF_2V500");
whismanoid 0:3edb3708c8c5 4664 cmdLine.serial().printf("\r\n 72 -- REF_2V048");
whismanoid 0:3edb3708c8c5 4665 cmdLine.serial().printf("\r\n 73 -- REF_4V096");
whismanoid 0:3edb3708c8c5 4666 cmdLine.serial().printf("\r\n 74 -- REF_AlwaysOn_EXT");
whismanoid 0:3edb3708c8c5 4667 cmdLine.serial().printf("\r\n 75 -- REF_AlwaysOn_2V500");
whismanoid 0:3edb3708c8c5 4668 cmdLine.serial().printf("\r\n 76 -- REF_AlwaysOn_2V048");
whismanoid 0:3edb3708c8c5 4669 cmdLine.serial().printf("\r\n 77 -- REF_AlwaysOn_4V096");
whismanoid 0:3edb3708c8c5 4670 cmdLine.serial().printf("\r\n 80 code=? -- CODEall");
whismanoid 0:3edb3708c8c5 4671 cmdLine.serial().printf("\r\n 81 -- LOADall");
whismanoid 0:3edb3708c8c5 4672 cmdLine.serial().printf("\r\n 82 code=? -- CODEallLOADall");
whismanoid 0:3edb3708c8c5 4673 //cmdLine.serial().printf("\r\n 83 code=? -- CODEallLOADall");
whismanoid 0:3edb3708c8c5 4674 //
whismanoid 0:3edb3708c8c5 4675 // Menu @ -- print device configuration
whismanoid 0:3edb3708c8c5 4676 cmdLine.serial().printf("\r\n @ -- print MAX5715 configuration");
whismanoid 0:3edb3708c8c5 4677 //
whismanoid 0:3edb3708c8c5 4678 // MAX5717 menu function to drive MAX5717_LDACb_Pin LDAC#
whismanoid 0:3edb3708c8c5 4679 // Note: '~' is not recommended for menu commands, interferes with ssh
whismanoid 0:3edb3708c8c5 4680 cmdLine.serial().printf("\r\n L -- LDAC# pulse LH high LL low");
whismanoid 0:3edb3708c8c5 4681 // MAX5717 menu function to drive MAX5717_CLRb_Pin CLR#
whismanoid 0:3edb3708c8c5 4682 cmdLine.serial().printf("\r\n C -- CLR# pulse CH high CL low");
whismanoid 0:3edb3708c8c5 4683 #endif // APPLICATION_MAX5715
whismanoid 0:3edb3708c8c5 4684 //
whismanoid 0:3edb3708c8c5 4685 #if APPLICATION_MAX11131 // main_menu_help
whismanoid 0:3edb3708c8c5 4686 // VERIFY: console menu command 0 int16_t MAX11131_ScanRead(void);
whismanoid 0:3edb3708c8c5 4687 cmdLine.serial().printf("\r\n 0 n=? -- MAX11131_ScanRead");
whismanoid 0:3edb3708c8c5 4688 // VERIFY: console menu command 1 MAX11131_ScanManual(int channelNumber_0_15, int PowerManagement_0_2, int chan_id_0_1);
whismanoid 0:3edb3708c8c5 4689 cmdLine.serial().printf("\r\n 1 ch=? pm=? id=? -- MAX11131_ScanManual");
whismanoid 0:3edb3708c8c5 4690 // VERIFY: console menu command 2 int MAX11131_ScanRepeat(uint8_t channelNumber_0_15, uint8_t average_0_4_8_16_32, uint8_t nscan_4_8_12_16, uint8_t PowerManagement_0_2, uint8_t swcnv_0_1);
whismanoid 0:3edb3708c8c5 4691 cmdLine.serial().printf("\r\n 2 ch=? av=? n=? pm=? swcnv=? -- MAX11131_ScanRepeat");
whismanoid 0:3edb3708c8c5 4692 // VERIFY: console menu command 3 MAX11131_ScanStandardInternalClock(int channelNumber_0_15, int average_0_4_8_16_32, int PowerManagement_0_2, int swcnv_0_1);
whismanoid 0:3edb3708c8c5 4693 cmdLine.serial().printf("\r\n 3 ch=? av=? pm=? swcnv=? -- MAX11131_ScanStandardIntClock");
whismanoid 0:3edb3708c8c5 4694 // VERIFY: console menu command 4 MAX11131_ScanStandardExternalClock(int channelNumber_0_15, int PowerManagement_0_2, int chan_id_0_1);
whismanoid 0:3edb3708c8c5 4695 cmdLine.serial().printf("\r\n 4 ch=? pm=? id=? -- MAX11131_ScanStandardExtClock");
whismanoid 0:3edb3708c8c5 4696 // VERIFY: console menu command 5 MAX11131_ScanUpperInternalClock(int channelNumber_0_15, int average_0_4_8_16_32, int PowerManagement_0_2, int swcnv_0_1);
whismanoid 0:3edb3708c8c5 4697 cmdLine.serial().printf("\r\n 5 ch=? av=? pm=? swcnv=? -- MAX11131_ScanUpperIntClock");
whismanoid 0:3edb3708c8c5 4698 // VERIFY: console menu command 6 MAX11131_ScanUpperExternalClock(int channelNumber_0_15, int PowerManagement_0_2, int chan_id_0_1);
whismanoid 0:3edb3708c8c5 4699 cmdLine.serial().printf("\r\n 6 ch=? pm=? id=? -- MAX11131_ScanUpperExtClock");
whismanoid 0:3edb3708c8c5 4700 // VERIFY: console menu command 7 MAX11131_ScanCustomInternalClock(int16_t enabledChannelsMask, int average_0_4_8_16_32, int PowerManagement_0_2, int swcnv_0_1);
whismanoid 0:3edb3708c8c5 4701 cmdLine.serial().printf("\r\n 7 enableMask=0xffff av=? pm=? swcnv=? -- MAX11131_ScanCustomIntClock");
whismanoid 0:3edb3708c8c5 4702 // VERIFY: console menu command 8 MAX11131_ScanCustomExternalClock(int16_t enabledChannelsMask, int PowerManagement_0_2, int chan_id_0_1);
whismanoid 0:3edb3708c8c5 4703 cmdLine.serial().printf("\r\n 8 enableMask=0xffff pm=0 id=1 -- MAX11131_ScanCustomExtClock");
whismanoid 0:3edb3708c8c5 4704 // VERIFY: console menu command 9 MAX11131_ScanSampleSetExternalClock(uint8_t enabledChannelsPatternLength_1_256, int16_t enabledChannelsPattern[], int PowerManagement_0_2, int chan_id_0_1);
whismanoid 0:3edb3708c8c5 4705 cmdLine.serial().printf("\r\n 9 channelsPattern... pm=? id=? | len=? -- MAX11131_ScanSampleSetExtClock");
whismanoid 0:3edb3708c8c5 4706 cmdLine.serial().printf("\r\n @ -- print MAX11131 configuration");
whismanoid 0:3edb3708c8c5 4707 cmdLine.serial().printf("\r\n ISc) IUc) IBc) IRc) reconfigure channel single-ended/unipolar/bipolar/range");
whismanoid 0:3edb3708c8c5 4708 // cmdLine.serial().printf("\r\n & -- MAX11131_Example_ScanManual");
whismanoid 0:3edb3708c8c5 4709 // Note: '~' is not recommended for menu commands, interferes with ssh
whismanoid 0:3edb3708c8c5 4710 #endif // APPLICATION_MAX11131
whismanoid 0:3edb3708c8c5 4711 //
whismanoid 0:3edb3708c8c5 4712 #if APPLICATION_MAX5171 // main_menu_help
whismanoid 0:3edb3708c8c5 4713 // TODO1: MAX5171 main_menu_help
whismanoid 0:3edb3708c8c5 4714 cmdLine.serial().printf("\r\n 0 code=? -- CODE");
whismanoid 0:3edb3708c8c5 4715 cmdLine.serial().printf("\r\n 4 code=? -- CODE_LOAD");
whismanoid 0:3edb3708c8c5 4716 cmdLine.serial().printf("\r\n 8 -- LOAD");
whismanoid 0:3edb3708c8c5 4717 cmdLine.serial().printf("\r\n c -- NOP");
whismanoid 0:3edb3708c8c5 4718 cmdLine.serial().printf("\r\n d -- SHUTDOWN");
whismanoid 0:3edb3708c8c5 4719 cmdLine.serial().printf("\r\n e0 -- UPO_LOW");
whismanoid 0:3edb3708c8c5 4720 cmdLine.serial().printf("\r\n e8 -- UPO_HIGH");
whismanoid 0:3edb3708c8c5 4721 cmdLine.serial().printf("\r\n f0 -- MODE1_DOUT_SCLK_RISING_EDGE");
whismanoid 0:3edb3708c8c5 4722 cmdLine.serial().printf("\r\n f8 -- MODE0_DOUT_SCLK_FALLING_EDGE");
whismanoid 0:3edb3708c8c5 4723 // Note: '~' is not recommended for menu commands, interferes with ssh
whismanoid 0:3edb3708c8c5 4724 #endif // APPLICATION_MAX5171
whismanoid 0:3edb3708c8c5 4725 //
whismanoid 0:3edb3708c8c5 4726 #if APPLICATION_MAX11410 // main_menu_help
whismanoid 0:3edb3708c8c5 4727 // TODO1: MAX11410 main_menu_help
whismanoid 0:3edb3708c8c5 4728 cmdLine.serial().printf("\r\n w reg=? data=? -- write register");
whismanoid 0:3edb3708c8c5 4729 cmdLine.serial().printf("\r\n r reg=? -- read register");
whismanoid 0:3edb3708c8c5 4730 cmdLine.serial().printf("\r\n TC -- thermocouple config");
whismanoid 0:3edb3708c8c5 4731 cmdLine.serial().printf("\r\n T -- RTD measurement");
whismanoid 0:3edb3708c8c5 4732 cmdLine.serial().printf("\r\n RC -- thermocouple config");
whismanoid 0:3edb3708c8c5 4733 cmdLine.serial().printf("\r\n R -- RTD measurement");
whismanoid 0:3edb3708c8c5 4734 // Note: '~' is not recommended for menu commands, interferes with ssh
whismanoid 0:3edb3708c8c5 4735 #endif // APPLICATION_MAX11410
whismanoid 0:3edb3708c8c5 4736 //
whismanoid 0:3edb3708c8c5 4737 #if APPLICATION_MAX12345 // main_menu_help
whismanoid 0:3edb3708c8c5 4738 cmdLine.serial().printf("\r\n 0 -- something");
whismanoid 0:3edb3708c8c5 4739 cmdLine.serial().printf("\r\n 1 -- something");
whismanoid 0:3edb3708c8c5 4740 cmdLine.serial().printf("\r\n 2 -- something");
whismanoid 0:3edb3708c8c5 4741 cmdLine.serial().printf("\r\n A -- something");
whismanoid 0:3edb3708c8c5 4742 cmdLine.serial().printf("\r\n B -- something");
whismanoid 0:3edb3708c8c5 4743 cmdLine.serial().printf("\r\n C -- something");
whismanoid 0:3edb3708c8c5 4744 // Note: '~' is not recommended for menu commands, interferes with ssh
whismanoid 0:3edb3708c8c5 4745 #endif // APPLICATION_MAX12345
whismanoid 0:3edb3708c8c5 4746 //
whismanoid 0:3edb3708c8c5 4747 }
whismanoid 0:3edb3708c8c5 4748
whismanoid 0:3edb3708c8c5 4749 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 4750 // main menu command-line parser
whismanoid 0:3edb3708c8c5 4751 // invoked by CmdLine::append(char ch) or CmdLine::idleAppendIfReadable()
whismanoid 0:3edb3708c8c5 4752 #if USE_COMMAND_BUFFER
whismanoid 0:3edb3708c8c5 4753 void main_menu_onEOLcommandParser(CmdLine & cmdLine)
whismanoid 0:3edb3708c8c5 4754 {
whismanoid 0:3edb3708c8c5 4755 // DIAGNOSTIC: print line buffer
whismanoid 0:3edb3708c8c5 4756 //~ cmdLine.serial().printf("\r\nmain_menu_onEOLcommandParser: ~%s~\r\n", cmdLine.str());
whismanoid 0:3edb3708c8c5 4757 //
whismanoid 0:3edb3708c8c5 4758 switch (cmdLine[0])
whismanoid 0:3edb3708c8c5 4759 {
whismanoid 0:3edb3708c8c5 4760 case '?':
whismanoid 0:3edb3708c8c5 4761 main_menu_status(cmdLine);
whismanoid 0:3edb3708c8c5 4762 main_menu_help(cmdLine);
whismanoid 0:3edb3708c8c5 4763 // print command prompt
whismanoid 0:3edb3708c8c5 4764 //cmdLine.serial().printf("\r\n>");
whismanoid 0:3edb3708c8c5 4765 break;
whismanoid 0:3edb3708c8c5 4766 case '\r': case '\n': // ignore blank line
whismanoid 0:3edb3708c8c5 4767 case '\0': // ignore empty line
whismanoid 0:3edb3708c8c5 4768 case '#': // ignore comment line
whismanoid 0:3edb3708c8c5 4769 // # -- lines beginning with # are comments
whismanoid 0:3edb3708c8c5 4770 main_menu_status(cmdLine);
whismanoid 0:3edb3708c8c5 4771 //~ main_menu_help(cmdLine);
whismanoid 0:3edb3708c8c5 4772 // print command prompt
whismanoid 0:3edb3708c8c5 4773 //cmdLine.serial().printf("\r\n>");
whismanoid 0:3edb3708c8c5 4774 break;
whismanoid 0:3edb3708c8c5 4775 #if ECHO_EOF_ON_EOL
whismanoid 0:3edb3708c8c5 4776 case '\x04': // Unicode (U+0004) EOT END OF TRANSMISSION = CTRL+D as EOF end of file
whismanoid 0:3edb3708c8c5 4777 cmdLine.serial().printf("\x04"); // immediately echo EOF for test scripting
whismanoid 0:3edb3708c8c5 4778 diagnostic_led_EOF();
whismanoid 0:3edb3708c8c5 4779 break;
whismanoid 0:3edb3708c8c5 4780 case '\x1a': // Unicode (U+001A) SUB SUBSTITUTE = CTRL+Z as EOF end of file
whismanoid 0:3edb3708c8c5 4781 cmdLine.serial().printf("\x1a"); // immediately echo EOF for test scripting
whismanoid 0:3edb3708c8c5 4782 diagnostic_led_EOF();
whismanoid 0:3edb3708c8c5 4783 break;
whismanoid 0:3edb3708c8c5 4784 #endif
whismanoid 0:3edb3708c8c5 4785 #if APPLICATION_ArduinoPinsMonitor
whismanoid 0:3edb3708c8c5 4786 case '.':
whismanoid 0:3edb3708c8c5 4787 {
whismanoid 0:3edb3708c8c5 4788 // . -- SelfTest
whismanoid 0:3edb3708c8c5 4789 cmdLine.serial().printf("SelfTest()");
whismanoid 0:3edb3708c8c5 4790 SelfTest(cmdLine);
whismanoid 0:3edb3708c8c5 4791 }
whismanoid 0:3edb3708c8c5 4792 break;
whismanoid 0:3edb3708c8c5 4793 case '%':
whismanoid 0:3edb3708c8c5 4794 {
whismanoid 0:3edb3708c8c5 4795 // TODO: consolidate "Arduino Pins Monitor" under '%' submenu -- APPLICATION_ArduinoPinsMonitor
whismanoid 0:3edb3708c8c5 4796 // % standardize diagnostic commands
whismanoid 0:3edb3708c8c5 4797 // %Hpin -- digital output high
whismanoid 0:3edb3708c8c5 4798 // %Lpin -- digital output low
whismanoid 0:3edb3708c8c5 4799 // %?pin -- digital input
whismanoid 0:3edb3708c8c5 4800 // %A %Apin -- analog input
whismanoid 0:3edb3708c8c5 4801 // %Ppin df=xx -- pwm output
whismanoid 0:3edb3708c8c5 4802 // %Wpin -- measure high pulsewidth input in usec
whismanoid 0:3edb3708c8c5 4803 // %wpin -- measure low pulsewidth input in usec
whismanoid 0:3edb3708c8c5 4804 // %I... -- I2C diagnostics
whismanoid 0:3edb3708c8c5 4805 // %IP -- I2C probe
whismanoid 0:3edb3708c8c5 4806 // %IC scl=100khz ADDR=? -- I2C configure
whismanoid 0:3edb3708c8c5 4807 // %IW byte byte ... byte RD=? ADDR=0x -- write
whismanoid 0:3edb3708c8c5 4808 // %IR ADDR=? RD=? -- read
whismanoid 0:3edb3708c8c5 4809 // %I^ cmd=? -- i2c_smbus_read_word_data
whismanoid 0:3edb3708c8c5 4810 // %S... -- SPI diagnostics
whismanoid 0:3edb3708c8c5 4811 // %SC sclk=1Mhz -- SPI configure
whismanoid 0:3edb3708c8c5 4812 // %SW -- write (write and read)
whismanoid 0:3edb3708c8c5 4813 // %SR -- read (alias for %SW because SPI always write and read)
whismanoid 0:3edb3708c8c5 4814 // A-Z,a-z,0-9 reserved for application use
whismanoid 0:3edb3708c8c5 4815 //
whismanoid 0:3edb3708c8c5 4816 // get pinIndex from cmdLine[2]
whismanoid 0:3edb3708c8c5 4817 //int pinIndex = cmdLine[2];
whismanoid 0:3edb3708c8c5 4818 // *** warning: pointer of type 'void *' used in arithmetic [-Wpointer-arith]
whismanoid 0:3edb3708c8c5 4819 //int pinIndex = strtoul((char *)((void *)(cmdLine.str()) + 2), NULL, 10); // strtol(str, NULL, 10): get decimal value
whismanoid 0:3edb3708c8c5 4820 // ^
whismanoid 0:3edb3708c8c5 4821 char strPinIndex[3];
whismanoid 0:3edb3708c8c5 4822 strPinIndex[0] = cmdLine[2];
whismanoid 0:3edb3708c8c5 4823 strPinIndex[1] = cmdLine[3];
whismanoid 0:3edb3708c8c5 4824 strPinIndex[2] = '\0';
whismanoid 0:3edb3708c8c5 4825 int pinIndex = strtoul(strPinIndex, NULL, 10); // strtol(str, NULL, 10): get decimal value
whismanoid 0:3edb3708c8c5 4826 //cmdLine.serial().printf(" pinIndex=%d ", pinIndex);
whismanoid 0:3edb3708c8c5 4827 //
whismanoid 0:3edb3708c8c5 4828 // get next character
whismanoid 0:3edb3708c8c5 4829 switch (cmdLine[1])
whismanoid 0:3edb3708c8c5 4830 {
whismanoid 0:3edb3708c8c5 4831 #if HAS_digitalInOuts
whismanoid 0:3edb3708c8c5 4832 case 'H': case 'h':
whismanoid 0:3edb3708c8c5 4833 {
whismanoid 0:3edb3708c8c5 4834 // %Hpin -- digital output high
whismanoid 0:3edb3708c8c5 4835 #if ARDUINO_STYLE
whismanoid 0:3edb3708c8c5 4836 pinMode(pinIndex, OUTPUT); // digital pins 0, 1, 2, .. 13, analog input pins A0, A1, .. A5
whismanoid 0:3edb3708c8c5 4837 digitalWrite(pinIndex, HIGH); // digital pins 0, 1, 2, .. 13, analog input pins A0, A1, .. A5
whismanoid 0:3edb3708c8c5 4838 #else
whismanoid 0:3edb3708c8c5 4839 DigitalInOut& digitalInOutPin = find_digitalInOutPin(pinIndex);
whismanoid 0:3edb3708c8c5 4840 digitalInOutPin.output();
whismanoid 0:3edb3708c8c5 4841 digitalInOutPin.write(1);
whismanoid 0:3edb3708c8c5 4842 #endif
whismanoid 0:3edb3708c8c5 4843 cmdLine.serial().printf(" digitalInOutPin %d Output High ", pinIndex);
whismanoid 0:3edb3708c8c5 4844 }
whismanoid 0:3edb3708c8c5 4845 break;
whismanoid 0:3edb3708c8c5 4846 case 'L': case 'l':
whismanoid 0:3edb3708c8c5 4847 {
whismanoid 0:3edb3708c8c5 4848 // %Lpin -- digital output low
whismanoid 0:3edb3708c8c5 4849 #if ARDUINO_STYLE
whismanoid 0:3edb3708c8c5 4850 pinMode(pinIndex, OUTPUT); // digital pins 0, 1, 2, .. 13, analog input pins A0, A1, .. A5
whismanoid 0:3edb3708c8c5 4851 digitalWrite(pinIndex, LOW); // digital pins 0, 1, 2, .. 13, analog input pins A0, A1, .. A5
whismanoid 0:3edb3708c8c5 4852 #else
whismanoid 0:3edb3708c8c5 4853 DigitalInOut& digitalInOutPin = find_digitalInOutPin(pinIndex);
whismanoid 0:3edb3708c8c5 4854 digitalInOutPin.output();
whismanoid 0:3edb3708c8c5 4855 digitalInOutPin.write(0);
whismanoid 0:3edb3708c8c5 4856 #endif
whismanoid 0:3edb3708c8c5 4857 cmdLine.serial().printf(" digitalInOutPin %d Output Low ", pinIndex);
whismanoid 0:3edb3708c8c5 4858 }
whismanoid 0:3edb3708c8c5 4859 break;
whismanoid 0:3edb3708c8c5 4860 case '?':
whismanoid 0:3edb3708c8c5 4861 {
whismanoid 0:3edb3708c8c5 4862 // %?pin -- digital input
whismanoid 0:3edb3708c8c5 4863 #if ARDUINO_STYLE
whismanoid 0:3edb3708c8c5 4864 pinMode(pinIndex, INPUT); // digital pins 0, 1, 2, .. 13, analog input pins A0, A1, .. A5
whismanoid 0:3edb3708c8c5 4865 #else
whismanoid 0:3edb3708c8c5 4866 DigitalInOut& digitalInOutPin = find_digitalInOutPin(pinIndex);
whismanoid 0:3edb3708c8c5 4867 digitalInOutPin.input();
whismanoid 0:3edb3708c8c5 4868 #endif
whismanoid 0:3edb3708c8c5 4869 microUSBserial.printf(" digitalInOutPin %d Input ", pinIndex);
whismanoid 0:3edb3708c8c5 4870 #if ARDUINO_STYLE
whismanoid 0:3edb3708c8c5 4871 int value = digitalRead(pinIndex);
whismanoid 0:3edb3708c8c5 4872 #else
whismanoid 0:3edb3708c8c5 4873 int value = digitalInOutPin.read();
whismanoid 0:3edb3708c8c5 4874 #endif
whismanoid 0:3edb3708c8c5 4875 cmdLine.serial().printf("%d ", value);
whismanoid 0:3edb3708c8c5 4876 }
whismanoid 0:3edb3708c8c5 4877 break;
whismanoid 0:3edb3708c8c5 4878 #endif
whismanoid 0:3edb3708c8c5 4879 //
whismanoid 0:3edb3708c8c5 4880 #if HAS_analogIns
whismanoid 0:3edb3708c8c5 4881 case 'A': case 'a':
whismanoid 0:3edb3708c8c5 4882 {
whismanoid 0:3edb3708c8c5 4883 // %A %Apin -- analog input
whismanoid 0:3edb3708c8c5 4884 #if analogIn4_IS_HIGH_RANGE_OF_analogIn0
whismanoid 0:3edb3708c8c5 4885 // Platform board uses AIN4,AIN5,.. as high range of AIN0,AIN1,..
whismanoid 0:3edb3708c8c5 4886 for (int pinIndex = 0; pinIndex < 2; pinIndex++)
whismanoid 0:3edb3708c8c5 4887 {
whismanoid 0:3edb3708c8c5 4888 int cPinIndex = '0' + pinIndex;
whismanoid 0:3edb3708c8c5 4889 AnalogIn& analogInPin = find_analogInPin(cPinIndex);
whismanoid 0:3edb3708c8c5 4890 float adc_full_scale_voltage = analogInPin_fullScaleVoltage[pinIndex];
whismanoid 0:3edb3708c8c5 4891 float normValue_0_1 = analogInPin.read();
whismanoid 0:3edb3708c8c5 4892 //
whismanoid 0:3edb3708c8c5 4893 int pinIndexH = pinIndex + 4;
whismanoid 0:3edb3708c8c5 4894 int cPinIndexH = '0' + pinIndexH;
whismanoid 0:3edb3708c8c5 4895 AnalogIn& analogInPinH = find_analogInPin(cPinIndexH);
whismanoid 0:3edb3708c8c5 4896 float adc_full_scale_voltageH = analogInPin_fullScaleVoltage[pinIndexH];
whismanoid 0:3edb3708c8c5 4897 float normValueH_0_1 = analogInPinH.read();
whismanoid 0:3edb3708c8c5 4898 //
whismanoid 0:3edb3708c8c5 4899 cmdLine.serial().printf("AIN%c = %7.3f%% = %1.3fV AIN%c = %7.3f%% = %1.3fV \r\n",
whismanoid 0:3edb3708c8c5 4900 cPinIndex,
whismanoid 0:3edb3708c8c5 4901 normValue_0_1 * 100.0,
whismanoid 0:3edb3708c8c5 4902 normValue_0_1 * adc_full_scale_voltage,
whismanoid 0:3edb3708c8c5 4903 cPinIndexH,
whismanoid 0:3edb3708c8c5 4904 normValueH_0_1 * 100.0,
whismanoid 0:3edb3708c8c5 4905 normValueH_0_1 * adc_full_scale_voltageH
whismanoid 0:3edb3708c8c5 4906 );
whismanoid 0:3edb3708c8c5 4907 }
whismanoid 0:3edb3708c8c5 4908 for (int pinIndex = 2; pinIndex < 4; pinIndex++)
whismanoid 0:3edb3708c8c5 4909 {
whismanoid 0:3edb3708c8c5 4910 int cPinIndex = '0' + pinIndex;
whismanoid 0:3edb3708c8c5 4911 AnalogIn& analogInPin = find_analogInPin(cPinIndex);
whismanoid 0:3edb3708c8c5 4912 float adc_full_scale_voltage = analogInPin_fullScaleVoltage[pinIndex];
whismanoid 0:3edb3708c8c5 4913 float normValue_0_1 = analogInPin.read();
whismanoid 0:3edb3708c8c5 4914 //
whismanoid 0:3edb3708c8c5 4915 cmdLine.serial().printf("AIN%c = %7.3f%% = %1.3fV\r\n",
whismanoid 0:3edb3708c8c5 4916 cPinIndex,
whismanoid 0:3edb3708c8c5 4917 normValue_0_1 * 100.0,
whismanoid 0:3edb3708c8c5 4918 normValue_0_1 * adc_full_scale_voltage
whismanoid 0:3edb3708c8c5 4919 );
whismanoid 0:3edb3708c8c5 4920 }
whismanoid 0:3edb3708c8c5 4921 #else // analogIn4_IS_HIGH_RANGE_OF_analogIn0
whismanoid 0:3edb3708c8c5 4922 // Platform board uses simple analog inputs
whismanoid 0:3edb3708c8c5 4923 // assume standard Arduino analog inputs A0-A5
whismanoid 0:3edb3708c8c5 4924 for (int pinIndex = 0; pinIndex < 6; pinIndex++)
whismanoid 0:3edb3708c8c5 4925 {
whismanoid 0:3edb3708c8c5 4926 int cPinIndex = '0' + pinIndex;
whismanoid 0:3edb3708c8c5 4927 AnalogIn& analogInPin = find_analogInPin(cPinIndex);
whismanoid 0:3edb3708c8c5 4928 float adc_full_scale_voltage = analogInPin_fullScaleVoltage[pinIndex];
whismanoid 0:3edb3708c8c5 4929 float normValue_0_1 = analogInPin.read();
whismanoid 0:3edb3708c8c5 4930 //
whismanoid 0:3edb3708c8c5 4931 cmdLine.serial().printf("AIN%c = %7.3f%% = %1.3fV\r\n",
whismanoid 0:3edb3708c8c5 4932 cPinIndex,
whismanoid 0:3edb3708c8c5 4933 normValue_0_1 * 100.0,
whismanoid 0:3edb3708c8c5 4934 normValue_0_1 * adc_full_scale_voltage
whismanoid 0:3edb3708c8c5 4935 );
whismanoid 0:3edb3708c8c5 4936 }
whismanoid 0:3edb3708c8c5 4937 #endif // analogIn4_IS_HIGH_RANGE_OF_analogIn0
whismanoid 0:3edb3708c8c5 4938 }
whismanoid 0:3edb3708c8c5 4939 break;
whismanoid 0:3edb3708c8c5 4940 #endif
whismanoid 0:3edb3708c8c5 4941 //
whismanoid 0:3edb3708c8c5 4942 #if HAS_SPI2_MAX541
whismanoid 0:3edb3708c8c5 4943 case 'D': case 'd':
whismanoid 0:3edb3708c8c5 4944 {
whismanoid 0:3edb3708c8c5 4945 // %D -- DAC output MAX541 (SPI2) -- need cmdLine.parse_float(voltageV)
whismanoid 0:3edb3708c8c5 4946 // MAX541 max541(spi2_max541, spi2_max541_cs);
whismanoid 0:3edb3708c8c5 4947 float voltageV = max541.Get_Voltage();
whismanoid 0:3edb3708c8c5 4948 // if (cmdLine[2] == '+') {
whismanoid 0:3edb3708c8c5 4949 // // %D+
whismanoid 0:3edb3708c8c5 4950 // voltageV = voltageV * 1.25f;
whismanoid 0:3edb3708c8c5 4951 // if (voltageV >= max541.VRef) voltageV = max541.VRef;
whismanoid 0:3edb3708c8c5 4952 // SelfTest_MAX541_Voltage(cmdLine, max541, voltageV);
whismanoid 0:3edb3708c8c5 4953 // }
whismanoid 0:3edb3708c8c5 4954 // else if (cmdLine[2] == '-') {
whismanoid 0:3edb3708c8c5 4955 // // %D-
whismanoid 0:3edb3708c8c5 4956 // voltageV = voltageV * 0.75f;
whismanoid 0:3edb3708c8c5 4957 // if (voltageV < 0.1f) voltageV = 0.1f;
whismanoid 0:3edb3708c8c5 4958 // SelfTest_MAX541_Voltage(cmdLine, max541, voltageV);
whismanoid 0:3edb3708c8c5 4959 // }
whismanoid 0:3edb3708c8c5 4960 if (cmdLine.parse_float("V", voltageV))
whismanoid 0:3edb3708c8c5 4961 {
whismanoid 0:3edb3708c8c5 4962 // %D V=1.234 -- set voltage
whismanoid 0:3edb3708c8c5 4963 max541.Set_Voltage(voltageV);
whismanoid 0:3edb3708c8c5 4964 }
whismanoid 0:3edb3708c8c5 4965 else if (cmdLine.parse_float("TEST", voltageV))
whismanoid 0:3edb3708c8c5 4966 {
whismanoid 0:3edb3708c8c5 4967 // %D TEST=1.234 -- set voltage and compare with AIN0
whismanoid 0:3edb3708c8c5 4968 SelfTest_MAX541_Voltage(cmdLine, max541, voltageV);
whismanoid 0:3edb3708c8c5 4969 }
whismanoid 0:3edb3708c8c5 4970 else if (cmdLine.parse_float("CAL", voltageV))
whismanoid 0:3edb3708c8c5 4971 {
whismanoid 0:3edb3708c8c5 4972 // %D CAL=1.234 -- calibrate VRef and compare with AIN0
whismanoid 0:3edb3708c8c5 4973
whismanoid 0:3edb3708c8c5 4974 max541.Set_Code(0x8000); // we don't know the fullscale voltage yet, so set code to midscale
whismanoid 0:3edb3708c8c5 4975 double max541_midscale_V = analogInPin_fullScaleVoltage[4] * analogIn4.read(); // TARGET_MAX32630 J1.5 AIN_4 = AIN0 / 5.0 fullscale is 6.0V
whismanoid 0:3edb3708c8c5 4976 const int average_count = 100;
whismanoid 0:3edb3708c8c5 4977 const double average_K = 0.25;
whismanoid 0:3edb3708c8c5 4978 for (int count = 0; count < average_count; count++) {
whismanoid 0:3edb3708c8c5 4979 double measurement_V = analogInPin_fullScaleVoltage[4] * analogIn4.read(); // TARGET_MAX32630 J1.5 AIN_4 = AIN0 / 5.0 fullscale is 6.0V
whismanoid 0:3edb3708c8c5 4980 max541_midscale_V = ((1 - average_K) * max541_midscale_V) + (average_K * measurement_V);
whismanoid 0:3edb3708c8c5 4981 }
whismanoid 0:3edb3708c8c5 4982 max541.VRef = 2.0 * max541_midscale_V;
whismanoid 0:3edb3708c8c5 4983 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 4984 "\r\n MAX541 midscale = %1.3fV, so fullscale = %1.3fV",
whismanoid 0:3edb3708c8c5 4985 max541_midscale_V, max541.VRef);
whismanoid 0:3edb3708c8c5 4986 // Detect whether MAX541 is really connected to MAX32625MBED.AIN0/AIN4
whismanoid 0:3edb3708c8c5 4987 voltageV = 1.0f;
whismanoid 0:3edb3708c8c5 4988 SelfTest_MAX541_Voltage(cmdLine, max541, voltageV);
whismanoid 0:3edb3708c8c5 4989 }
whismanoid 0:3edb3708c8c5 4990 else {
whismanoid 0:3edb3708c8c5 4991 // %D -- print MAX541 DAC status
whismanoid 0:3edb3708c8c5 4992 cmdLine.serial().printf("MAX541 code=0x%4.4x = %1.3fV VRef=%1.3fV\r\n",
whismanoid 0:3edb3708c8c5 4993 max541.Get_Code(), max541.Get_Voltage(), max541.VRef);
whismanoid 0:3edb3708c8c5 4994 }
whismanoid 0:3edb3708c8c5 4995 }
whismanoid 0:3edb3708c8c5 4996 break;
whismanoid 0:3edb3708c8c5 4997 #endif
whismanoid 0:3edb3708c8c5 4998
whismanoid 0:3edb3708c8c5 4999 //
whismanoid 0:3edb3708c8c5 5000 #if HAS_pwmDrivers
whismanoid 0:3edb3708c8c5 5001 case 'P': case 'p':
whismanoid 0:3edb3708c8c5 5002 {
whismanoid 0:3edb3708c8c5 5003 // %Ppin df=xx -- pwm output
whismanoid 0:3edb3708c8c5 5004 }
whismanoid 0:3edb3708c8c5 5005 break;
whismanoid 0:3edb3708c8c5 5006 #endif
whismanoid 0:3edb3708c8c5 5007 //
whismanoid 0:3edb3708c8c5 5008 #if 0 // HAS_pwmDrivers
whismanoid 0:3edb3708c8c5 5009 case 'W':
whismanoid 0:3edb3708c8c5 5010 case 'w':
whismanoid 0:3edb3708c8c5 5011 // %Wpin -- measure high pulsewidth input in usec
whismanoid 0:3edb3708c8c5 5012 // %wpin -- measure low pulsewidth input in usec
whismanoid 0:3edb3708c8c5 5013 break;
whismanoid 0:3edb3708c8c5 5014 #endif
whismanoid 0:3edb3708c8c5 5015 //
whismanoid 0:3edb3708c8c5 5016 #if HAS_I2C // SUPPORT_I2C
whismanoid 0:3edb3708c8c5 5017 case 'I': case 'i':
whismanoid 0:3edb3708c8c5 5018 // %I... -- I2C diagnostics
whismanoid 0:3edb3708c8c5 5019 // %IP -- I2C probe
whismanoid 0:3edb3708c8c5 5020 // %IC scl=100khz ADDR=? -- I2C configure
whismanoid 0:3edb3708c8c5 5021 // %IW byte byte ... byte RD=? ADDR=0x -- write
whismanoid 0:3edb3708c8c5 5022 // %IR ADDR=? RD=? -- read
whismanoid 0:3edb3708c8c5 5023 // %I^ cmd=? -- i2c_smbus_read_word_data
whismanoid 0:3edb3708c8c5 5024 // get next character
whismanoid 0:3edb3708c8c5 5025 // TODO: parse cmdLine arg (ADDR=\d+)? --> g_I2C_deviceAddress7
whismanoid 0:3edb3708c8c5 5026 cmdLine.parse_byte_hex("ADDR", g_I2C_deviceAddress7);
whismanoid 0:3edb3708c8c5 5027 // TODO: parse cmdLine arg (RD=\d)? --> g_I2C_read_count
whismanoid 0:3edb3708c8c5 5028 g_I2C_read_count = 0; // read count must be reset every command
whismanoid 0:3edb3708c8c5 5029 cmdLine.parse_byte_dec("RD", g_I2C_read_count);
whismanoid 0:3edb3708c8c5 5030 // TODO: parse cmdLine arg (CMD=\d)? --> g_I2C_command_regAddress
whismanoid 0:3edb3708c8c5 5031 cmdLine.parse_byte_hex("CMD", g_I2C_command_regAddress);
whismanoid 0:3edb3708c8c5 5032 switch (cmdLine[2])
whismanoid 0:3edb3708c8c5 5033 {
whismanoid 0:3edb3708c8c5 5034 case 'P': case 'p':
whismanoid 0:3edb3708c8c5 5035 {
whismanoid 0:3edb3708c8c5 5036 // %IP -- I2C probe
whismanoid 0:3edb3708c8c5 5037 HuntAttachedI2CDevices(cmdLine, 0x03, 0x77);
whismanoid 0:3edb3708c8c5 5038 }
whismanoid 0:3edb3708c8c5 5039 break;
whismanoid 0:3edb3708c8c5 5040 case 'C': case 'c':
whismanoid 0:3edb3708c8c5 5041 {
whismanoid 0:3edb3708c8c5 5042 bool isUpdatedI2CConfig = false;
whismanoid 0:3edb3708c8c5 5043 // %IC scl=100khz ADDR=? -- I2C configure
whismanoid 0:3edb3708c8c5 5044 // parse cmdLine arg (SCL=\d+(kHZ|MHZ)?)? --> g_I2C_SCL_Hz
whismanoid 0:3edb3708c8c5 5045 if (cmdLine.parse_frequency_Hz("SCL", g_I2C_SCL_Hz))
whismanoid 0:3edb3708c8c5 5046 {
whismanoid 0:3edb3708c8c5 5047 isUpdatedI2CConfig = true;
whismanoid 0:3edb3708c8c5 5048 // TODO1: validate g_I2C_SCL_Hz against system clock frequency F_CPU
whismanoid 0:3edb3708c8c5 5049 if (g_I2C_SCL_Hz > limit_max_I2C_SCL_Hz)
whismanoid 0:3edb3708c8c5 5050 {
whismanoid 0:3edb3708c8c5 5051 g_I2C_SCL_Hz = limit_max_I2C_SCL_Hz;
whismanoid 0:3edb3708c8c5 5052 }
whismanoid 0:3edb3708c8c5 5053 if (g_I2C_SCL_Hz < limit_min_I2C_SCL_Hz)
whismanoid 0:3edb3708c8c5 5054 {
whismanoid 0:3edb3708c8c5 5055 g_I2C_SCL_Hz = limit_min_I2C_SCL_Hz;
whismanoid 0:3edb3708c8c5 5056 }
whismanoid 0:3edb3708c8c5 5057 }
whismanoid 0:3edb3708c8c5 5058 if (isUpdatedI2CConfig)
whismanoid 0:3edb3708c8c5 5059 {
whismanoid 0:3edb3708c8c5 5060 // declare in narrower scope: MAX32625MBED I2C i2cMaster(...)
whismanoid 0:3edb3708c8c5 5061 I2C i2cMaster(I2C0_SDA, I2C0_SCL); // sda scl TARGET_MAX32635MBED: P1_6, P1_7 Arduino 10-pin header
whismanoid 0:3edb3708c8c5 5062 i2cMaster.frequency(g_I2C_SCL_Hz);
whismanoid 0:3edb3708c8c5 5063 i2cMaster.start();
whismanoid 0:3edb3708c8c5 5064 i2cMaster.stop();
whismanoid 0:3edb3708c8c5 5065 i2cMaster.frequency(g_I2C_SCL_Hz);
whismanoid 0:3edb3708c8c5 5066 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 5067 "\r\n %%IC ADDR=0x%2.2x=(0x%2.2x>>1) SCL=%d=%1.3fkHz -- I2C config",
whismanoid 0:3edb3708c8c5 5068 g_I2C_deviceAddress7, (g_I2C_deviceAddress7 << 1), g_I2C_SCL_Hz,
whismanoid 0:3edb3708c8c5 5069 (g_I2C_SCL_Hz / 1000.));
whismanoid 0:3edb3708c8c5 5070 i2cMaster.start();
whismanoid 0:3edb3708c8c5 5071 i2cMaster.stop();
whismanoid 0:3edb3708c8c5 5072 }
whismanoid 0:3edb3708c8c5 5073 }
whismanoid 0:3edb3708c8c5 5074 break;
whismanoid 0:3edb3708c8c5 5075 case 'W': case 'w':
whismanoid 0:3edb3708c8c5 5076 {
whismanoid 0:3edb3708c8c5 5077 // declare in narrower scope: MAX32625MBED I2C i2cMaster(...)
whismanoid 0:3edb3708c8c5 5078 I2C i2cMaster(I2C0_SDA, I2C0_SCL); // sda scl TARGET_MAX32635MBED: P1_6, P1_7 Arduino 10-pin header
whismanoid 0:3edb3708c8c5 5079 i2cMaster.frequency(g_I2C_SCL_Hz);
whismanoid 0:3edb3708c8c5 5080 // %IW byte byte ... byte RD=? ADDR=0x -- write
whismanoid 0:3edb3708c8c5 5081 // parse cmdLine byte list --> int byteCount; int mosiData[MAX_SPI_BYTE_COUNT];
whismanoid 0:3edb3708c8c5 5082 #define MAX_I2C_BYTE_COUNT 32
whismanoid 0:3edb3708c8c5 5083 size_t byteCount = byteCount;
whismanoid 0:3edb3708c8c5 5084 static char mosiData[MAX_I2C_BYTE_COUNT];
whismanoid 0:3edb3708c8c5 5085 static char misoData[MAX_I2C_BYTE_COUNT];
whismanoid 0:3edb3708c8c5 5086 if (cmdLine.parse_byteCount_byteList_hex(byteCount, mosiData,
whismanoid 0:3edb3708c8c5 5087 MAX_I2C_BYTE_COUNT))
whismanoid 0:3edb3708c8c5 5088 {
whismanoid 0:3edb3708c8c5 5089 // hex dump mosiData[0..byteCount-1]
whismanoid 0:3edb3708c8c5 5090 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 5091 "\r\nADDR=0x%2.2x=(0x%2.2x>>1) byteCount:%d RD=%d\r\nI2C MOSI->",
whismanoid 0:3edb3708c8c5 5092 g_I2C_deviceAddress7,
whismanoid 0:3edb3708c8c5 5093 (g_I2C_deviceAddress7 << 1), byteCount, g_I2C_read_count);
whismanoid 0:3edb3708c8c5 5094 for (unsigned int byteIndex = 0; byteIndex < byteCount; byteIndex++)
whismanoid 0:3edb3708c8c5 5095 {
whismanoid 0:3edb3708c8c5 5096 cmdLine.serial().printf(" 0x%2.2X", mosiData[byteIndex]);
whismanoid 0:3edb3708c8c5 5097 }
whismanoid 0:3edb3708c8c5 5098 //
whismanoid 0:3edb3708c8c5 5099 // TODO: i2c transfer
whismanoid 0:3edb3708c8c5 5100 //const int addr7bit = 0x48; // 7 bit I2C address
whismanoid 0:3edb3708c8c5 5101 //const int addr8bit = 0x48 << 1; // 8bit I2C address, 0x90
whismanoid 0:3edb3708c8c5 5102 // /* int */ i2cMaster.read (int addr8bit, char *data, int length, bool repeated=false) // Read from an I2C slave.
whismanoid 0:3edb3708c8c5 5103 // /* int */ i2cMaster.read (int ack) // Read a single byte from the I2C bus.
whismanoid 0:3edb3708c8c5 5104 // /* int */ i2cMaster.write (int addr8bit, const char *data, int length, bool repeated=false) // Write to an I2C slave.
whismanoid 0:3edb3708c8c5 5105 // /* int */ i2cMaster.write (int data) // Write single byte out on the I2C bus.
whismanoid 0:3edb3708c8c5 5106 // /* void */ i2cMaster.start (void) // Creates a start condition on the I2C bus.
whismanoid 0:3edb3708c8c5 5107 // /* void */ i2cMaster.stop (void) // Creates a stop condition on the I2C bus.
whismanoid 0:3edb3708c8c5 5108 // /* int */ i2cMaster.transfer (int addr8bit, const char *tx_buffer, int tx_length, char *rx_buffer, int rx_length, const event_callback_t &callback, int event=I2C_EVENT_TRANSFER_COMPLETE, bool repeated=false) // Start nonblocking I2C transfer. More...
whismanoid 0:3edb3708c8c5 5109 // /* void */ i2cMaster.abort_transfer () // Abort the ongoing I2C transfer. More...
whismanoid 0:3edb3708c8c5 5110 const int addr8bit = g_I2C_deviceAddress7 << 1; // 8bit I2C address, 0x90
whismanoid 0:3edb3708c8c5 5111 unsigned int misoLength = 0;
whismanoid 0:3edb3708c8c5 5112 bool repeated = (g_I2C_read_count > 0);
whismanoid 0:3edb3708c8c5 5113 //
whismanoid 0:3edb3708c8c5 5114 int writeStatus = i2cMaster.write (addr8bit, mosiData, byteCount, repeated);
whismanoid 0:3edb3708c8c5 5115 switch (writeStatus)
whismanoid 0:3edb3708c8c5 5116 {
whismanoid 0:3edb3708c8c5 5117 case 0: cmdLine.serial().printf(" ack "); break;
whismanoid 0:3edb3708c8c5 5118 case 1: cmdLine.serial().printf(" nack "); break;
whismanoid 0:3edb3708c8c5 5119 default: cmdLine.serial().printf(" {writeStatus 0x%2.2X} ",
whismanoid 0:3edb3708c8c5 5120 writeStatus);
whismanoid 0:3edb3708c8c5 5121 }
whismanoid 0:3edb3708c8c5 5122 if (repeated)
whismanoid 0:3edb3708c8c5 5123 {
whismanoid 0:3edb3708c8c5 5124 int readStatus =
whismanoid 0:3edb3708c8c5 5125 i2cMaster.read (addr8bit, misoData, g_I2C_read_count, false);
whismanoid 0:3edb3708c8c5 5126 switch (readStatus)
whismanoid 0:3edb3708c8c5 5127 {
whismanoid 0:3edb3708c8c5 5128 case 1: cmdLine.serial().printf(" nack "); break;
whismanoid 0:3edb3708c8c5 5129 case 0: cmdLine.serial().printf(" ack "); break;
whismanoid 0:3edb3708c8c5 5130 default: cmdLine.serial().printf(" {readStatus 0x%2.2X} ",
whismanoid 0:3edb3708c8c5 5131 readStatus);
whismanoid 0:3edb3708c8c5 5132 }
whismanoid 0:3edb3708c8c5 5133 }
whismanoid 0:3edb3708c8c5 5134 //
whismanoid 0:3edb3708c8c5 5135 if (misoLength > 0)
whismanoid 0:3edb3708c8c5 5136 {
whismanoid 0:3edb3708c8c5 5137 // hex dump misoData[0..byteCount-1]
whismanoid 0:3edb3708c8c5 5138 cmdLine.serial().printf(" MISO<-");
whismanoid 0:3edb3708c8c5 5139 for (unsigned int byteIndex = 0; byteIndex < g_I2C_read_count;
whismanoid 0:3edb3708c8c5 5140 byteIndex++)
whismanoid 0:3edb3708c8c5 5141 {
whismanoid 0:3edb3708c8c5 5142 cmdLine.serial().printf(" 0x%2.2X", misoData[byteIndex]);
whismanoid 0:3edb3708c8c5 5143 }
whismanoid 0:3edb3708c8c5 5144 }
whismanoid 0:3edb3708c8c5 5145 cmdLine.serial().printf(" ");
whismanoid 0:3edb3708c8c5 5146 }
whismanoid 0:3edb3708c8c5 5147 }
whismanoid 0:3edb3708c8c5 5148 break;
whismanoid 0:3edb3708c8c5 5149 case 'R': case 'r':
whismanoid 0:3edb3708c8c5 5150 {
whismanoid 0:3edb3708c8c5 5151 // declare in narrower scope: MAX32625MBED I2C i2cMaster(...)
whismanoid 0:3edb3708c8c5 5152 I2C i2cMaster(I2C0_SDA, I2C0_SCL); // sda scl TARGET_MAX32635MBED: P1_6, P1_7 Arduino 10-pin header
whismanoid 0:3edb3708c8c5 5153 i2cMaster.frequency(g_I2C_SCL_Hz);
whismanoid 0:3edb3708c8c5 5154 // %IR ADDR=? RD=? -- read
whismanoid 0:3edb3708c8c5 5155 // TODO: i2c transfer
whismanoid 0:3edb3708c8c5 5156 //const int addr7bit = 0x48; // 7 bit I2C address
whismanoid 0:3edb3708c8c5 5157 //const int addr8bit = 0x48 << 1; // 8bit I2C address, 0x90
whismanoid 0:3edb3708c8c5 5158 // /* int */ i2cMaster.read (int addr8bit, char *data, int length, bool repeated=false) // Read from an I2C slave.
whismanoid 0:3edb3708c8c5 5159 // /* int */ i2cMaster.read (int ack) // Read a single byte from the I2C bus.
whismanoid 0:3edb3708c8c5 5160 // /* int */ i2cMaster.write (int addr8bit, const char *data, int length, bool repeated=false) // Write to an I2C slave.
whismanoid 0:3edb3708c8c5 5161 // /* int */ i2cMaster.write (int data) // Write single byte out on the I2C bus.
whismanoid 0:3edb3708c8c5 5162 // /* void */ i2cMaster.start (void) // Creates a start condition on the I2C bus.
whismanoid 0:3edb3708c8c5 5163 // /* void */ i2cMaster.stop (void) // Creates a stop condition on the I2C bus.
whismanoid 0:3edb3708c8c5 5164 // /* int */ i2cMaster.transfer (int addr8bit, const char *tx_buffer, int tx_length, char *rx_buffer, int rx_length, const event_callback_t &callback, int event=I2C_EVENT_TRANSFER_COMPLETE, bool repeated=false) // Start nonblocking I2C transfer. More...
whismanoid 0:3edb3708c8c5 5165 // /* void */ i2cMaster.abort_transfer () // Abort the ongoing I2C transfer. More...
whismanoid 0:3edb3708c8c5 5166 }
whismanoid 0:3edb3708c8c5 5167 break;
whismanoid 0:3edb3708c8c5 5168 case '^':
whismanoid 0:3edb3708c8c5 5169 {
whismanoid 0:3edb3708c8c5 5170 // declare in narrower scope: MAX32625MBED I2C i2cMaster(...)
whismanoid 0:3edb3708c8c5 5171 I2C i2cMaster(I2C0_SDA, I2C0_SCL); // sda scl TARGET_MAX32635MBED: P1_6, P1_7 Arduino 10-pin header
whismanoid 0:3edb3708c8c5 5172 i2cMaster.frequency(g_I2C_SCL_Hz);
whismanoid 0:3edb3708c8c5 5173 // %I^ cmd=? -- i2c_smbus_read_word_data
whismanoid 0:3edb3708c8c5 5174 // TODO: i2c transfer
whismanoid 0:3edb3708c8c5 5175 //const int addr7bit = 0x48; // 7 bit I2C address
whismanoid 0:3edb3708c8c5 5176 //const int addr8bit = 0x48 << 1; // 8bit I2C address, 0x90
whismanoid 0:3edb3708c8c5 5177 // /* int */ i2cMaster.read (int addr8bit, char *data, int length, bool repeated=false) // Read from an I2C slave.
whismanoid 0:3edb3708c8c5 5178 // /* int */ i2cMaster.read (int ack) // Read a single byte from the I2C bus.
whismanoid 0:3edb3708c8c5 5179 // /* int */ i2cMaster.write (int addr8bit, const char *data, int length, bool repeated=false) // Write to an I2C slave.
whismanoid 0:3edb3708c8c5 5180 // /* int */ i2cMaster.write (int data) // Write single byte out on the I2C bus.
whismanoid 0:3edb3708c8c5 5181 // /* void */ i2cMaster.start (void) // Creates a start condition on the I2C bus.
whismanoid 0:3edb3708c8c5 5182 // /* void */ i2cMaster.stop (void) // Creates a stop condition on the I2C bus.
whismanoid 0:3edb3708c8c5 5183 // /* int */ i2cMaster.transfer (int addr8bit, const char *tx_buffer, int tx_length, char *rx_buffer, int rx_length, const event_callback_t &callback, int event=I2C_EVENT_TRANSFER_COMPLETE, bool repeated=false) // Start nonblocking I2C transfer. More...
whismanoid 0:3edb3708c8c5 5184 // /* void */ i2cMaster.abort_transfer () // Abort the ongoing I2C transfer. More...
whismanoid 0:3edb3708c8c5 5185 }
whismanoid 0:3edb3708c8c5 5186 break;
whismanoid 0:3edb3708c8c5 5187 } // switch(cmdLine[2])
whismanoid 0:3edb3708c8c5 5188 break;
whismanoid 0:3edb3708c8c5 5189 #endif
whismanoid 0:3edb3708c8c5 5190 //
whismanoid 0:3edb3708c8c5 5191 #if HAS_SPI // SUPPORT_SPI
whismanoid 0:3edb3708c8c5 5192 case 'S': case 's':
whismanoid 0:3edb3708c8c5 5193 {
whismanoid 0:3edb3708c8c5 5194 // %S... -- SPI diagnostics
whismanoid 0:3edb3708c8c5 5195 // %SC sclk=1Mhz -- SPI configure
whismanoid 0:3edb3708c8c5 5196 // %SW -- write (write and read)
whismanoid 0:3edb3708c8c5 5197 // %SR -- read (alias for %SW because SPI always write and read)
whismanoid 0:3edb3708c8c5 5198 //
whismanoid 0:3edb3708c8c5 5199 // Process arguments SCLK=\d+(kHZ|MHZ) CPOL=\d CPHA=\d
whismanoid 0:3edb3708c8c5 5200 bool isUpdatedSPIConfig = false;
whismanoid 0:3edb3708c8c5 5201 // parse cmdLine arg (CPOL=\d)? --> g_SPI_dataMode | SPI_MODE2
whismanoid 0:3edb3708c8c5 5202 // parse cmdLine arg (CPHA=\d)? --> g_SPI_dataMode | SPI_MODE1
whismanoid 0:3edb3708c8c5 5203 if (cmdLine.parse_flag("CPOL", g_SPI_dataMode, SPI_MODE2))
whismanoid 0:3edb3708c8c5 5204 {
whismanoid 0:3edb3708c8c5 5205 isUpdatedSPIConfig = true;
whismanoid 0:3edb3708c8c5 5206 }
whismanoid 0:3edb3708c8c5 5207 if (cmdLine.parse_flag("CPHA", g_SPI_dataMode, SPI_MODE1))
whismanoid 0:3edb3708c8c5 5208 {
whismanoid 0:3edb3708c8c5 5209 isUpdatedSPIConfig = true;
whismanoid 0:3edb3708c8c5 5210 }
whismanoid 0:3edb3708c8c5 5211 if (cmdLine.parse_flag("CS", g_SPI_cs_state, 1))
whismanoid 0:3edb3708c8c5 5212 {
whismanoid 0:3edb3708c8c5 5213 isUpdatedSPIConfig = true;
whismanoid 0:3edb3708c8c5 5214 }
whismanoid 0:3edb3708c8c5 5215 // parse cmdLine arg (SCLK=\d+(kHZ|MHZ)?)? --> g_SPI_SCLK_Hz
whismanoid 0:3edb3708c8c5 5216 if (cmdLine.parse_frequency_Hz("SCLK", g_SPI_SCLK_Hz))
whismanoid 0:3edb3708c8c5 5217 {
whismanoid 0:3edb3708c8c5 5218 isUpdatedSPIConfig = true;
whismanoid 0:3edb3708c8c5 5219 // TODO1: validate g_SPI_SCLK_Hz against system clock frequency F_CPU
whismanoid 0:3edb3708c8c5 5220 if (g_SPI_SCLK_Hz > limit_max_SPI_SCLK_Hz)
whismanoid 0:3edb3708c8c5 5221 {
whismanoid 0:3edb3708c8c5 5222 g_SPI_SCLK_Hz = limit_max_SPI_SCLK_Hz;
whismanoid 0:3edb3708c8c5 5223 }
whismanoid 0:3edb3708c8c5 5224 if (g_SPI_SCLK_Hz < limit_min_SPI_SCLK_Hz)
whismanoid 0:3edb3708c8c5 5225 {
whismanoid 0:3edb3708c8c5 5226 g_SPI_SCLK_Hz = limit_min_SPI_SCLK_Hz;
whismanoid 0:3edb3708c8c5 5227 }
whismanoid 0:3edb3708c8c5 5228 }
whismanoid 0:3edb3708c8c5 5229 // Update SPI configuration
whismanoid 0:3edb3708c8c5 5230 if (isUpdatedSPIConfig)
whismanoid 0:3edb3708c8c5 5231 {
whismanoid 0:3edb3708c8c5 5232 // %SC sclk=1Mhz -- SPI configure
whismanoid 0:3edb3708c8c5 5233 spi_cs = g_SPI_cs_state;
whismanoid 0:3edb3708c8c5 5234 spi.format(8,g_SPI_dataMode); // int bits_must_be_8, int mode=0_3 CPOL=0,CPHA=0
whismanoid 0:3edb3708c8c5 5235 #if APPLICATION_MAX5715
whismanoid 0:3edb3708c8c5 5236 g_MAX5715_device.spi_frequency(g_SPI_SCLK_Hz);
whismanoid 0:3edb3708c8c5 5237 #elif APPLICATION_MAX11131
whismanoid 0:3edb3708c8c5 5238 g_MAX11131_device.spi_frequency(g_SPI_SCLK_Hz);
whismanoid 0:3edb3708c8c5 5239 #elif APPLICATION_MAX5171
whismanoid 0:3edb3708c8c5 5240 g_MAX5171_device.spi_frequency(g_SPI_SCLK_Hz);
whismanoid 0:3edb3708c8c5 5241 #elif APPLICATION_MAX11410
whismanoid 0:3edb3708c8c5 5242 g_MAX11410_device.spi_frequency(g_SPI_SCLK_Hz);
whismanoid 0:3edb3708c8c5 5243 #elif APPLICATION_MAX12345
whismanoid 0:3edb3708c8c5 5244 g_MAX12345_device.spi_frequency(g_SPI_SCLK_Hz);
whismanoid 0:3edb3708c8c5 5245 #else
whismanoid 0:3edb3708c8c5 5246 spi.frequency(g_SPI_SCLK_Hz); // int SCLK_Hz=1000000 = 1MHz (initial default)
whismanoid 0:3edb3708c8c5 5247 #endif
whismanoid 0:3edb3708c8c5 5248 //
whismanoid 0:3edb3708c8c5 5249 double ideal_divisor = ((double)SystemCoreClock) / g_SPI_SCLK_Hz;
whismanoid 0:3edb3708c8c5 5250 int actual_divisor = (int)(ideal_divisor + 0.0); // frequency divisor truncate
whismanoid 0:3edb3708c8c5 5251 double actual_SCLK_Hz = SystemCoreClock / actual_divisor;
whismanoid 0:3edb3708c8c5 5252 //
whismanoid 0:3edb3708c8c5 5253 // fixed: mbed-os-5.11: [Warning] format '%d' expects argument of type 'int', but argument 6 has type 'uint32_t {aka long unsigned int}' [-Wformat=]
whismanoid 0:3edb3708c8c5 5254 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 5255 "\r\n %%SC CPOL=%d CPHA=%d CS=%d SCLK=%ld=%1.3fMHz (%1.1fMHz/%1.2f = actual %1.3fMHz) -- SPI config",
whismanoid 0:3edb3708c8c5 5256 ((g_SPI_dataMode & SPI_MODE2) ? 1 : 0),
whismanoid 0:3edb3708c8c5 5257 ((g_SPI_dataMode & SPI_MODE1) ? 1 : 0),
whismanoid 0:3edb3708c8c5 5258 g_SPI_cs_state,
whismanoid 0:3edb3708c8c5 5259 g_SPI_SCLK_Hz,
whismanoid 0:3edb3708c8c5 5260 (g_SPI_SCLK_Hz / 1000000.),
whismanoid 0:3edb3708c8c5 5261 ((double)(SystemCoreClock / 1000000.)),
whismanoid 0:3edb3708c8c5 5262 ideal_divisor,
whismanoid 0:3edb3708c8c5 5263 (actual_SCLK_Hz / 1000000.)
whismanoid 0:3edb3708c8c5 5264 );
whismanoid 0:3edb3708c8c5 5265 }
whismanoid 0:3edb3708c8c5 5266 // get next character
whismanoid 0:3edb3708c8c5 5267 switch (cmdLine[2])
whismanoid 0:3edb3708c8c5 5268 {
whismanoid 0:3edb3708c8c5 5269 case 'C': case 's':
whismanoid 0:3edb3708c8c5 5270 // %SC sclk=1Mhz -- SPI configure
whismanoid 0:3edb3708c8c5 5271 break;
whismanoid 0:3edb3708c8c5 5272 case 'W': case 'R': case 'w': case 'r':
whismanoid 0:3edb3708c8c5 5273 {
whismanoid 0:3edb3708c8c5 5274 // %SW -- write (write and read)
whismanoid 0:3edb3708c8c5 5275 // %SR -- read (alias for %SW because SPI always write and read)
whismanoid 0:3edb3708c8c5 5276 // parse cmdLine byte list --> int byteCount; int mosiData[MAX_SPI_BYTE_COUNT];
whismanoid 0:3edb3708c8c5 5277 #define MAX_SPI_BYTE_COUNT 32
whismanoid 0:3edb3708c8c5 5278 size_t byteCount = byteCount;
whismanoid 0:3edb3708c8c5 5279 static char mosiData[MAX_SPI_BYTE_COUNT];
whismanoid 0:3edb3708c8c5 5280 static char misoData[MAX_SPI_BYTE_COUNT];
whismanoid 0:3edb3708c8c5 5281 if (cmdLine.parse_byteCount_byteList_hex(byteCount, mosiData,
whismanoid 0:3edb3708c8c5 5282 MAX_SPI_BYTE_COUNT))
whismanoid 0:3edb3708c8c5 5283 {
whismanoid 0:3edb3708c8c5 5284 // hex dump mosiData[0..byteCount-1]
whismanoid 0:3edb3708c8c5 5285 cmdLine.serial().printf("\r\nSPI");
whismanoid 0:3edb3708c8c5 5286 if (byteCount > 7) {
whismanoid 0:3edb3708c8c5 5287 cmdLine.serial().printf(" byteCount:%d", byteCount);
whismanoid 0:3edb3708c8c5 5288 }
whismanoid 0:3edb3708c8c5 5289 cmdLine.serial().printf(" MOSI->");
whismanoid 0:3edb3708c8c5 5290 for (unsigned int byteIndex = 0; byteIndex < byteCount; byteIndex++)
whismanoid 0:3edb3708c8c5 5291 {
whismanoid 0:3edb3708c8c5 5292 cmdLine.serial().printf(" 0x%2.2X", mosiData[byteIndex]);
whismanoid 0:3edb3708c8c5 5293 }
whismanoid 0:3edb3708c8c5 5294 spi_cs = 0;
whismanoid 0:3edb3708c8c5 5295 unsigned int numBytesTransferred =
whismanoid 0:3edb3708c8c5 5296 spi.write(mosiData, byteCount, misoData, byteCount);
whismanoid 0:3edb3708c8c5 5297 spi_cs = 1;
whismanoid 0:3edb3708c8c5 5298 // hex dump misoData[0..byteCount-1]
whismanoid 0:3edb3708c8c5 5299 cmdLine.serial().printf(" MISO<-");
whismanoid 0:3edb3708c8c5 5300 for (unsigned int byteIndex = 0; byteIndex < numBytesTransferred;
whismanoid 0:3edb3708c8c5 5301 byteIndex++)
whismanoid 0:3edb3708c8c5 5302 {
whismanoid 0:3edb3708c8c5 5303 cmdLine.serial().printf(" 0x%2.2X", misoData[byteIndex]);
whismanoid 0:3edb3708c8c5 5304 }
whismanoid 0:3edb3708c8c5 5305 cmdLine.serial().printf(" ");
whismanoid 0:3edb3708c8c5 5306 }
whismanoid 0:3edb3708c8c5 5307 }
whismanoid 0:3edb3708c8c5 5308 break;
whismanoid 0:3edb3708c8c5 5309 } // switch(cmdLine[2])
whismanoid 0:3edb3708c8c5 5310 } // case 'S': // %S... -- SPI diagnostics
whismanoid 0:3edb3708c8c5 5311 break;
whismanoid 0:3edb3708c8c5 5312 #endif
whismanoid 0:3edb3708c8c5 5313 //
whismanoid 0:3edb3708c8c5 5314 // A-Z,a-z,0-9 reserved for application use
whismanoid 0:3edb3708c8c5 5315 } // switch(cmdLine[1])
whismanoid 0:3edb3708c8c5 5316 }
whismanoid 0:3edb3708c8c5 5317 break; // case '%'
whismanoid 0:3edb3708c8c5 5318 #endif // APPLICATION_ArduinoPinsMonitor
whismanoid 0:3edb3708c8c5 5319 //
whismanoid 0:3edb3708c8c5 5320 // Application-specific commands here
whismanoid 0:3edb3708c8c5 5321 // alphanumeric command codes A-Z,a-z,0-9 reserved for application use
whismanoid 0:3edb3708c8c5 5322 //
whismanoid 0:3edb3708c8c5 5323 #if APPLICATION_ArduinoPinsMonitor
whismanoid 0:3edb3708c8c5 5324 #endif // APPLICATION_ArduinoPinsMonitor
whismanoid 0:3edb3708c8c5 5325
whismanoid 0:3edb3708c8c5 5326 #if APPLICATION_MAX5715 // main_menu_onEOLcommandParser
whismanoid 0:3edb3708c8c5 5327 case '0':
whismanoid 0:3edb3708c8c5 5328 {
whismanoid 0:3edb3708c8c5 5329 // recommended for hex command codes 00..0F
whismanoid 0:3edb3708c8c5 5330 // TODO: cmdLine.serial().printf("\r\n 0 ch=? code=? -- CODEn");
whismanoid 0:3edb3708c8c5 5331 // Menu 0 ch=? code=?) CODEn
whismanoid 0:3edb3708c8c5 5332 // MAX5715_CODEn(uint8_t channel, uint16_t dacCodeLsbs);
whismanoid 0:3edb3708c8c5 5333 // VERIFY: parse strCommandArgs for additional arguments including key=value pairs
whismanoid 0:3edb3708c8c5 5334 // TODO: parse command arguments ~ parse_strCommandArgs(strCommandArgs);
whismanoid 0:3edb3708c8c5 5335 uint16_t ch = g_MAX5715_device.channelNumber_0_3;
whismanoid 0:3edb3708c8c5 5336 if (cmdLine.parse_uint16_dec("ch", ch))
whismanoid 0:3edb3708c8c5 5337 {
whismanoid 0:3edb3708c8c5 5338 }
whismanoid 0:3edb3708c8c5 5339 uint16_t code = g_MAX5715_device.CODE[ch];
whismanoid 0:3edb3708c8c5 5340 if (cmdLine.parse_uint16_dec("code", code))
whismanoid 0:3edb3708c8c5 5341 {
whismanoid 0:3edb3708c8c5 5342 }
whismanoid 0:3edb3708c8c5 5343 cmdLine.serial().printf("CODEn ch=%d code=%d", ch, code);
whismanoid 0:3edb3708c8c5 5344 g_MAX5715_device.CODEn(ch, code);
whismanoid 0:3edb3708c8c5 5345 }
whismanoid 0:3edb3708c8c5 5346 break;
whismanoid 0:3edb3708c8c5 5347 case '1':
whismanoid 0:3edb3708c8c5 5348 {
whismanoid 0:3edb3708c8c5 5349 // recommended for hex command codes 10..1F
whismanoid 0:3edb3708c8c5 5350 // TODO: cmdLine.serial().printf("\r\n 1 ch=? -- LOADn");
whismanoid 0:3edb3708c8c5 5351 // TODO: parse command arguments ~ parse_strCommandArgs(strCommandArgs);
whismanoid 0:3edb3708c8c5 5352 uint16_t ch = g_MAX5715_device.channelNumber_0_3;
whismanoid 0:3edb3708c8c5 5353 if (cmdLine.parse_uint16_dec("ch", ch))
whismanoid 0:3edb3708c8c5 5354 {
whismanoid 0:3edb3708c8c5 5355 }
whismanoid 0:3edb3708c8c5 5356 cmdLine.serial().printf("LOADn ch=%d", ch);
whismanoid 0:3edb3708c8c5 5357 g_MAX5715_device.LOADn(ch);
whismanoid 0:3edb3708c8c5 5358 }
whismanoid 0:3edb3708c8c5 5359 break;
whismanoid 0:3edb3708c8c5 5360 case '2':
whismanoid 0:3edb3708c8c5 5361 {
whismanoid 0:3edb3708c8c5 5362 // recommended for hex command codes 20..2F
whismanoid 0:3edb3708c8c5 5363 // TODO: cmdLine.serial().printf("\r\n 2 ch=? code=? -- CODEnLOADall");
whismanoid 0:3edb3708c8c5 5364 // TODO: parse command arguments ~ parse_strCommandArgs(strCommandArgs);
whismanoid 0:3edb3708c8c5 5365 uint16_t ch = g_MAX5715_device.channelNumber_0_3;
whismanoid 0:3edb3708c8c5 5366 if (cmdLine.parse_uint16_dec("ch", ch))
whismanoid 0:3edb3708c8c5 5367 {
whismanoid 0:3edb3708c8c5 5368 }
whismanoid 0:3edb3708c8c5 5369 uint16_t code = g_MAX5715_device.CODE[ch];
whismanoid 0:3edb3708c8c5 5370 if (cmdLine.parse_uint16_dec("code", code))
whismanoid 0:3edb3708c8c5 5371 {
whismanoid 0:3edb3708c8c5 5372 }
whismanoid 0:3edb3708c8c5 5373 cmdLine.serial().printf("CODEnLOADall ch=%d code=%d", ch, code);
whismanoid 0:3edb3708c8c5 5374 g_MAX5715_device.CODEnLOADall(ch, code);
whismanoid 0:3edb3708c8c5 5375 }
whismanoid 0:3edb3708c8c5 5376 break;
whismanoid 0:3edb3708c8c5 5377 case '3':
whismanoid 0:3edb3708c8c5 5378 {
whismanoid 0:3edb3708c8c5 5379 // recommended for hex command codes 30..3F
whismanoid 0:3edb3708c8c5 5380 // TODO: cmdLine.serial().printf("\r\n 3 ch=? code=? -- CODEnLOADn");
whismanoid 0:3edb3708c8c5 5381 // TODO: parse command arguments ~ parse_strCommandArgs(strCommandArgs);
whismanoid 0:3edb3708c8c5 5382 uint16_t ch = g_MAX5715_device.channelNumber_0_3;
whismanoid 0:3edb3708c8c5 5383 uint16_t code;
whismanoid 0:3edb3708c8c5 5384 if (cmdLine.parse_uint16_dec("ch", ch))
whismanoid 0:3edb3708c8c5 5385 {
whismanoid 0:3edb3708c8c5 5386 }
whismanoid 0:3edb3708c8c5 5387 if (cmdLine.parse_uint16_dec("code", code))
whismanoid 0:3edb3708c8c5 5388 {
whismanoid 0:3edb3708c8c5 5389 }
whismanoid 0:3edb3708c8c5 5390 cmdLine.serial().printf("CODEnLOADn ch=%d code=%d", ch, code);
whismanoid 0:3edb3708c8c5 5391 g_MAX5715_device.CODEnLOADn(ch, code);
whismanoid 0:3edb3708c8c5 5392 }
whismanoid 0:3edb3708c8c5 5393 break;
whismanoid 0:3edb3708c8c5 5394 case '4':
whismanoid 0:3edb3708c8c5 5395 {
whismanoid 0:3edb3708c8c5 5396 // recommended for hex command codes 40..4F
whismanoid 0:3edb3708c8c5 5397 switch (cmdLine[1])
whismanoid 0:3edb3708c8c5 5398 {
whismanoid 0:3edb3708c8c5 5399 case '0':
whismanoid 0:3edb3708c8c5 5400 {
whismanoid 0:3edb3708c8c5 5401 // cmdLine.serial().printf("\r\n 40 ch=? -- POWERn_Normal");
whismanoid 0:3edb3708c8c5 5402 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 5403 "channel_dcba=%d, POWERn_Normal)",
whismanoid 0:3edb3708c8c5 5404 g_MAX5715_device.channels_bitmask_DCBA);
whismanoid 0:3edb3708c8c5 5405 g_MAX5715_device.POWER(g_MAX5715_device.
whismanoid 0:3edb3708c8c5 5406 channels_bitmask_DCBA,
whismanoid 0:3edb3708c8c5 5407 MAX5715::POWERn_Normal);
whismanoid 0:3edb3708c8c5 5408 }
whismanoid 0:3edb3708c8c5 5409 break;
whismanoid 0:3edb3708c8c5 5410 case '1':
whismanoid 0:3edb3708c8c5 5411 {
whismanoid 0:3edb3708c8c5 5412 // cmdLine.serial().printf("\r\n 41 ch=? -- POWERn_PD1k");
whismanoid 0:3edb3708c8c5 5413 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 5414 "channel_dcba=%d, POWERn_PD1k)",
whismanoid 0:3edb3708c8c5 5415 g_MAX5715_device.channels_bitmask_DCBA);
whismanoid 0:3edb3708c8c5 5416 g_MAX5715_device.POWER(g_MAX5715_device.
whismanoid 0:3edb3708c8c5 5417 channels_bitmask_DCBA,
whismanoid 0:3edb3708c8c5 5418 MAX5715::POWERn_PD1k);
whismanoid 0:3edb3708c8c5 5419 }
whismanoid 0:3edb3708c8c5 5420 break;
whismanoid 0:3edb3708c8c5 5421 case '2':
whismanoid 0:3edb3708c8c5 5422 {
whismanoid 0:3edb3708c8c5 5423 // cmdLine.serial().printf("\r\n 42 ch=? -- POWERn_PD100k");
whismanoid 0:3edb3708c8c5 5424 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 5425 "channel_dcba=%d, POWERn_PD100k)",
whismanoid 0:3edb3708c8c5 5426 g_MAX5715_device.channels_bitmask_DCBA);
whismanoid 0:3edb3708c8c5 5427 g_MAX5715_device.POWER(g_MAX5715_device.
whismanoid 0:3edb3708c8c5 5428 channels_bitmask_DCBA,
whismanoid 0:3edb3708c8c5 5429 MAX5715::POWERn_PD100k);
whismanoid 0:3edb3708c8c5 5430 }
whismanoid 0:3edb3708c8c5 5431 break;
whismanoid 0:3edb3708c8c5 5432 case '3':
whismanoid 0:3edb3708c8c5 5433 {
whismanoid 0:3edb3708c8c5 5434 // cmdLine.serial().printf("\r\n 43 ch=? -- POWERn_PDHiZ");
whismanoid 0:3edb3708c8c5 5435 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 5436 "channel_dcba=%d, POWERn_PDHiZ)",
whismanoid 0:3edb3708c8c5 5437 g_MAX5715_device.channels_bitmask_DCBA);
whismanoid 0:3edb3708c8c5 5438 g_MAX5715_device.POWER(g_MAX5715_device.
whismanoid 0:3edb3708c8c5 5439 channels_bitmask_DCBA,
whismanoid 0:3edb3708c8c5 5440 MAX5715::POWERn_PDHiZ);
whismanoid 0:3edb3708c8c5 5441 }
whismanoid 0:3edb3708c8c5 5442 break;
whismanoid 0:3edb3708c8c5 5443 }
whismanoid 0:3edb3708c8c5 5444 break;
whismanoid 0:3edb3708c8c5 5445 }
whismanoid 0:3edb3708c8c5 5446 break;
whismanoid 0:3edb3708c8c5 5447 case '5':
whismanoid 0:3edb3708c8c5 5448 {
whismanoid 0:3edb3708c8c5 5449 // recommended for hex command codes 50..5F
whismanoid 0:3edb3708c8c5 5450 switch (cmdLine[1])
whismanoid 0:3edb3708c8c5 5451 {
whismanoid 0:3edb3708c8c5 5452 case '0':
whismanoid 0:3edb3708c8c5 5453 {
whismanoid 0:3edb3708c8c5 5454 // cmdLine.serial().printf("\r\n 50 -- SW_CLEAR");
whismanoid 0:3edb3708c8c5 5455 cmdLine.serial().printf("SW_CLEAR");
whismanoid 0:3edb3708c8c5 5456 g_MAX5715_device.SW_CLEAR();
whismanoid 0:3edb3708c8c5 5457 }
whismanoid 0:3edb3708c8c5 5458 break;
whismanoid 0:3edb3708c8c5 5459 case '1':
whismanoid 0:3edb3708c8c5 5460 {
whismanoid 0:3edb3708c8c5 5461 // cmdLine.serial().printf("\r\n 51 -- SW_RESET");
whismanoid 0:3edb3708c8c5 5462 cmdLine.serial().printf("SW_RESET");
whismanoid 0:3edb3708c8c5 5463 g_MAX5715_device.SW_RESET();
whismanoid 0:3edb3708c8c5 5464 }
whismanoid 0:3edb3708c8c5 5465 break;
whismanoid 0:3edb3708c8c5 5466 }
whismanoid 0:3edb3708c8c5 5467 }
whismanoid 0:3edb3708c8c5 5468 break;
whismanoid 0:3edb3708c8c5 5469 case '6':
whismanoid 0:3edb3708c8c5 5470 {
whismanoid 0:3edb3708c8c5 5471 // recommended for hex command codes 60..6F
whismanoid 0:3edb3708c8c5 5472 switch (cmdLine[1])
whismanoid 0:3edb3708c8c5 5473 {
whismanoid 0:3edb3708c8c5 5474 case '0':
whismanoid 0:3edb3708c8c5 5475 {
whismanoid 0:3edb3708c8c5 5476 // cmdLine.serial().printf("\r\n 60 ch=? -- CONFIGn_LATCHED");
whismanoid 0:3edb3708c8c5 5477 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 5478 "MAX5715_CONFIGn_LATCHED(channel_dcba=%d)",
whismanoid 0:3edb3708c8c5 5479 g_MAX5715_device.
whismanoid 0:3edb3708c8c5 5480 channels_bitmask_DCBA);
whismanoid 0:3edb3708c8c5 5481 g_MAX5715_device.CONFIGn_LATCHED(g_MAX5715_device.
whismanoid 0:3edb3708c8c5 5482 channels_bitmask_DCBA);
whismanoid 0:3edb3708c8c5 5483 }
whismanoid 0:3edb3708c8c5 5484 break;
whismanoid 0:3edb3708c8c5 5485 case '1':
whismanoid 0:3edb3708c8c5 5486 {
whismanoid 0:3edb3708c8c5 5487 // cmdLine.serial().printf("\r\n 61 ch=? -- CONFIGn_TRANSPARENT");
whismanoid 0:3edb3708c8c5 5488 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 5489 "MAX5715_CONFIGn_TRANSPARENT(channel_dcba=%d)",
whismanoid 0:3edb3708c8c5 5490 g_MAX5715_device.
whismanoid 0:3edb3708c8c5 5491 channels_bitmask_DCBA);
whismanoid 0:3edb3708c8c5 5492 g_MAX5715_device.CONFIGn_TRANSPARENT(
whismanoid 0:3edb3708c8c5 5493 g_MAX5715_device.channels_bitmask_DCBA);
whismanoid 0:3edb3708c8c5 5494 }
whismanoid 0:3edb3708c8c5 5495 break;
whismanoid 0:3edb3708c8c5 5496 case '8':
whismanoid 0:3edb3708c8c5 5497 {
whismanoid 0:3edb3708c8c5 5498 // cmdLine.serial().printf("\r\n 68 -- CONFIGall_LATCHED");
whismanoid 0:3edb3708c8c5 5499 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 5500 "MAX5715_CONFIGall_LATCHED()");
whismanoid 0:3edb3708c8c5 5501 g_MAX5715_device.CONFIGall_LATCHED();
whismanoid 0:3edb3708c8c5 5502 }
whismanoid 0:3edb3708c8c5 5503 break;
whismanoid 0:3edb3708c8c5 5504 case '9':
whismanoid 0:3edb3708c8c5 5505 {
whismanoid 0:3edb3708c8c5 5506 // cmdLine.serial().printf("\r\n 69 -- CONFIGall_TRANSPARENT");
whismanoid 0:3edb3708c8c5 5507 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 5508 "MAX5715_CONFIGall_TRANSPARENT()");
whismanoid 0:3edb3708c8c5 5509 g_MAX5715_device.CONFIGall_TRANSPARENT();
whismanoid 0:3edb3708c8c5 5510 }
whismanoid 0:3edb3708c8c5 5511 break;
whismanoid 0:3edb3708c8c5 5512 }
whismanoid 0:3edb3708c8c5 5513 }
whismanoid 0:3edb3708c8c5 5514 break;
whismanoid 0:3edb3708c8c5 5515 case '7':
whismanoid 0:3edb3708c8c5 5516 {
whismanoid 0:3edb3708c8c5 5517 // recommended for hex command codes 70..7F
whismanoid 0:3edb3708c8c5 5518 switch (cmdLine[1])
whismanoid 0:3edb3708c8c5 5519 {
whismanoid 0:3edb3708c8c5 5520 case '0':
whismanoid 0:3edb3708c8c5 5521 {
whismanoid 0:3edb3708c8c5 5522 // cmdLine.serial().printf("\r\n 70 -- REF_EXT");
whismanoid 0:3edb3708c8c5 5523 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 5524 "MAX5715_REF(REF_EXT)");
whismanoid 0:3edb3708c8c5 5525 g_MAX5715_device.REF(MAX5715::REF_EXT);
whismanoid 0:3edb3708c8c5 5526 }
whismanoid 0:3edb3708c8c5 5527 break;
whismanoid 0:3edb3708c8c5 5528 case '1':
whismanoid 0:3edb3708c8c5 5529 {
whismanoid 0:3edb3708c8c5 5530 // cmdLine.serial().printf("\r\n 71 -- REF_2V500");
whismanoid 0:3edb3708c8c5 5531 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 5532 "MAX5715_REF(REF_2V500)");
whismanoid 0:3edb3708c8c5 5533 g_MAX5715_device.REF(MAX5715::REF_2V500);
whismanoid 0:3edb3708c8c5 5534 }
whismanoid 0:3edb3708c8c5 5535 break;
whismanoid 0:3edb3708c8c5 5536 case '2':
whismanoid 0:3edb3708c8c5 5537 {
whismanoid 0:3edb3708c8c5 5538 // cmdLine.serial().printf("\r\n 72 -- REF_2V048");
whismanoid 0:3edb3708c8c5 5539 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 5540 "MAX5715_REF(REF_2V048)");
whismanoid 0:3edb3708c8c5 5541 g_MAX5715_device.REF(MAX5715::REF_2V048);
whismanoid 0:3edb3708c8c5 5542 }
whismanoid 0:3edb3708c8c5 5543 break;
whismanoid 0:3edb3708c8c5 5544 case '3':
whismanoid 0:3edb3708c8c5 5545 {
whismanoid 0:3edb3708c8c5 5546 // cmdLine.serial().printf("\r\n 73 -- REF_4V096");
whismanoid 0:3edb3708c8c5 5547 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 5548 "MAX5715_REF(REF_4V096)");
whismanoid 0:3edb3708c8c5 5549 g_MAX5715_device.REF(MAX5715::REF_4V096);
whismanoid 0:3edb3708c8c5 5550 }
whismanoid 0:3edb3708c8c5 5551 break;
whismanoid 0:3edb3708c8c5 5552 case '4':
whismanoid 0:3edb3708c8c5 5553 {
whismanoid 0:3edb3708c8c5 5554 // cmdLine.serial().printf("\r\n 74 -- REF_AlwaysOn_EXT");
whismanoid 0:3edb3708c8c5 5555 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 5556 "MAX5715_REF(REF_AlwaysOn_EXT)");
whismanoid 0:3edb3708c8c5 5557 g_MAX5715_device.REF(MAX5715::REF_AlwaysOn_EXT);
whismanoid 0:3edb3708c8c5 5558 }
whismanoid 0:3edb3708c8c5 5559 break;
whismanoid 0:3edb3708c8c5 5560 case '5':
whismanoid 0:3edb3708c8c5 5561 {
whismanoid 0:3edb3708c8c5 5562 // cmdLine.serial().printf("\r\n 75 -- REF_AlwaysOn_2V500");
whismanoid 0:3edb3708c8c5 5563 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 5564 "MAX5715_REF(REF_AlwaysOn_2V500)");
whismanoid 0:3edb3708c8c5 5565 g_MAX5715_device.REF(MAX5715::REF_AlwaysOn_2V500);
whismanoid 0:3edb3708c8c5 5566 }
whismanoid 0:3edb3708c8c5 5567 break;
whismanoid 0:3edb3708c8c5 5568 case '6':
whismanoid 0:3edb3708c8c5 5569 {
whismanoid 0:3edb3708c8c5 5570 // cmdLine.serial().printf("\r\n 76 -- REF_AlwaysOn_2V048");
whismanoid 0:3edb3708c8c5 5571 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 5572 "MAX5715_REF(REF_AlwaysOn_2V048)");
whismanoid 0:3edb3708c8c5 5573 g_MAX5715_device.REF(MAX5715::REF_AlwaysOn_2V048);
whismanoid 0:3edb3708c8c5 5574 }
whismanoid 0:3edb3708c8c5 5575 break;
whismanoid 0:3edb3708c8c5 5576 case '7':
whismanoid 0:3edb3708c8c5 5577 {
whismanoid 0:3edb3708c8c5 5578 // cmdLine.serial().printf("\r\n 77 -- REF_AlwaysOn_4V096");
whismanoid 0:3edb3708c8c5 5579 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 5580 "MAX5715_REF(REF_AlwaysOn_4V096)");
whismanoid 0:3edb3708c8c5 5581 g_MAX5715_device.REF(MAX5715::REF_AlwaysOn_4V096);
whismanoid 0:3edb3708c8c5 5582 }
whismanoid 0:3edb3708c8c5 5583 break;
whismanoid 0:3edb3708c8c5 5584 }
whismanoid 0:3edb3708c8c5 5585 }
whismanoid 0:3edb3708c8c5 5586 break;
whismanoid 0:3edb3708c8c5 5587 case '8':
whismanoid 0:3edb3708c8c5 5588 {
whismanoid 0:3edb3708c8c5 5589 // recommended for hex command codes 80..8F
whismanoid 0:3edb3708c8c5 5590 switch (cmdLine[1])
whismanoid 0:3edb3708c8c5 5591 {
whismanoid 0:3edb3708c8c5 5592 case '0':
whismanoid 0:3edb3708c8c5 5593 {
whismanoid 0:3edb3708c8c5 5594 // TODO: cmdLine.serial().printf("\r\n 80 code=? -- CODEall");
whismanoid 0:3edb3708c8c5 5595 // TODO: parse command arguments ~ parse_strCommandArgs(strCommandArgs);
whismanoid 0:3edb3708c8c5 5596 g_MAX5715_device.channels_bitmask_DCBA = 0xFF; // store g_MAX5715_device.CODE[allChannels]
whismanoid 0:3edb3708c8c5 5597 uint16_t code = g_MAX5715_device.CODE[0];
whismanoid 0:3edb3708c8c5 5598 if (cmdLine.parse_uint16_dec("code", code))
whismanoid 0:3edb3708c8c5 5599 {
whismanoid 0:3edb3708c8c5 5600 }
whismanoid 0:3edb3708c8c5 5601 cmdLine.serial().printf("CODEall code=%d", code);
whismanoid 0:3edb3708c8c5 5602 g_MAX5715_device.CODEall(code);
whismanoid 0:3edb3708c8c5 5603 }
whismanoid 0:3edb3708c8c5 5604 break;
whismanoid 0:3edb3708c8c5 5605 case '1':
whismanoid 0:3edb3708c8c5 5606 {
whismanoid 0:3edb3708c8c5 5607 // TODO: cmdLine.serial().printf("\r\n 81 -- LOADall");
whismanoid 0:3edb3708c8c5 5608 cmdLine.serial().printf("LOADall");
whismanoid 0:3edb3708c8c5 5609 g_MAX5715_device.LOADall();
whismanoid 0:3edb3708c8c5 5610 }
whismanoid 0:3edb3708c8c5 5611 break;
whismanoid 0:3edb3708c8c5 5612 case '2':
whismanoid 0:3edb3708c8c5 5613 {
whismanoid 0:3edb3708c8c5 5614 // TODO: cmdLine.serial().printf("\r\n 82 code=? -- CODEallLOADall");
whismanoid 0:3edb3708c8c5 5615 uint16_t code = g_MAX5715_device.CODE[0];
whismanoid 0:3edb3708c8c5 5616 if (cmdLine.parse_uint16_dec("code", code))
whismanoid 0:3edb3708c8c5 5617 {
whismanoid 0:3edb3708c8c5 5618 }
whismanoid 0:3edb3708c8c5 5619 cmdLine.serial().printf("CODEallLOADall code=%d", code);
whismanoid 0:3edb3708c8c5 5620 g_MAX5715_device.CODEallLOADall(code);
whismanoid 0:3edb3708c8c5 5621 }
whismanoid 0:3edb3708c8c5 5622 break;
whismanoid 0:3edb3708c8c5 5623 }
whismanoid 0:3edb3708c8c5 5624 }
whismanoid 0:3edb3708c8c5 5625 break;
whismanoid 0:3edb3708c8c5 5626 case '9':
whismanoid 0:3edb3708c8c5 5627 {
whismanoid 0:3edb3708c8c5 5628 // recommended for hex command codes 90..9F
whismanoid 0:3edb3708c8c5 5629 }
whismanoid 0:3edb3708c8c5 5630 break;
whismanoid 0:3edb3708c8c5 5631 case 'a': case 'A':
whismanoid 0:3edb3708c8c5 5632 {
whismanoid 0:3edb3708c8c5 5633 // recommended for hex command codes A0..AF
whismanoid 0:3edb3708c8c5 5634 switch (cmdLine[1])
whismanoid 0:3edb3708c8c5 5635 {
whismanoid 0:3edb3708c8c5 5636 case 't': case 'T':
whismanoid 0:3edb3708c8c5 5637 #if IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 5638 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 5639 cmdLine_DAPLINKserial.serial().printf("\r\n ignore AT command \"%s\"\r\n", cmdLine.str());
whismanoid 0:3edb3708c8c5 5640 # endif // HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 5641 // AT command: skip the prompt to avoid confusing modem detector
whismanoid 0:3edb3708c8c5 5642 return;
whismanoid 0:3edb3708c8c5 5643 #endif // IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 5644 }
whismanoid 0:3edb3708c8c5 5645 }
whismanoid 0:3edb3708c8c5 5646 break;
whismanoid 0:3edb3708c8c5 5647 case 'b': case 'B':
whismanoid 0:3edb3708c8c5 5648 {
whismanoid 0:3edb3708c8c5 5649 // recommended for hex command codes B0..BF
whismanoid 0:3edb3708c8c5 5650 }
whismanoid 0:3edb3708c8c5 5651 break;
whismanoid 0:3edb3708c8c5 5652 case 'c': case 'C':
whismanoid 0:3edb3708c8c5 5653 {
whismanoid 0:3edb3708c8c5 5654 // recommended for hex command codes C0..CF
whismanoid 0:3edb3708c8c5 5655 // // MAX5717 menu function to drive MAX5717_CLRb_Pin CLR#
whismanoid 0:3edb3708c8c5 5656 // cmdLine.serial().printf("\r\n C -- CLR# pulse CH high CL low");
whismanoid 0:3edb3708c8c5 5657 switch (cmdLine[1])
whismanoid 0:3edb3708c8c5 5658 {
whismanoid 0:3edb3708c8c5 5659 default:
whismanoid 0:3edb3708c8c5 5660 // g_MAX5715_device.CLRboutputPulseLow();
whismanoid 0:3edb3708c8c5 5661 g_MAX5715_device.CLRboutputValue(1);
whismanoid 0:3edb3708c8c5 5662 g_MAX5715_device.CLRboutputValue(0);
whismanoid 0:3edb3708c8c5 5663 g_MAX5715_device.CLRboutputValue(1);
whismanoid 0:3edb3708c8c5 5664 break;
whismanoid 0:3edb3708c8c5 5665 case 'H': case 'h': case '1':
whismanoid 0:3edb3708c8c5 5666 g_MAX5715_device.CLRboutputValue(1); // GPIOoutputCLRb(int isLogicHigh);
whismanoid 0:3edb3708c8c5 5667 break;
whismanoid 0:3edb3708c8c5 5668 case 'L': case 'l': case '0':
whismanoid 0:3edb3708c8c5 5669 g_MAX5715_device.CLRboutputValue(0); // GPIOoutputCLRb(int isLogicHigh);
whismanoid 0:3edb3708c8c5 5670 break;
whismanoid 0:3edb3708c8c5 5671 }
whismanoid 0:3edb3708c8c5 5672 }
whismanoid 0:3edb3708c8c5 5673 break;
whismanoid 0:3edb3708c8c5 5674 case 'd': case 'D':
whismanoid 0:3edb3708c8c5 5675 {
whismanoid 0:3edb3708c8c5 5676 // recommended for hex command codes D0..DF
whismanoid 0:3edb3708c8c5 5677 }
whismanoid 0:3edb3708c8c5 5678 break;
whismanoid 0:3edb3708c8c5 5679 case 'e': case 'E':
whismanoid 0:3edb3708c8c5 5680 {
whismanoid 0:3edb3708c8c5 5681 // recommended for hex command codes E0..EF
whismanoid 0:3edb3708c8c5 5682 }
whismanoid 0:3edb3708c8c5 5683 break;
whismanoid 0:3edb3708c8c5 5684 case 'f': case 'F':
whismanoid 0:3edb3708c8c5 5685 {
whismanoid 0:3edb3708c8c5 5686 // recommended for hex command codes F0..FF
whismanoid 0:3edb3708c8c5 5687 }
whismanoid 0:3edb3708c8c5 5688 break;
whismanoid 0:3edb3708c8c5 5689 case 'l': case 'L':
whismanoid 0:3edb3708c8c5 5690 {
whismanoid 0:3edb3708c8c5 5691 // // MAX5717 menu function to drive MAX5717_LDACb_Pin LDAC#
whismanoid 0:3edb3708c8c5 5692 // cmdLine.serial().printf("\r\n L -- LDAC# pulse LH high LL low");
whismanoid 0:3edb3708c8c5 5693 switch (cmdLine[1])
whismanoid 0:3edb3708c8c5 5694 {
whismanoid 0:3edb3708c8c5 5695 default:
whismanoid 0:3edb3708c8c5 5696 // g_MAX5715_device.LDACboutputPulseLow();
whismanoid 0:3edb3708c8c5 5697 g_MAX5715_device.LDACboutputValue(1);
whismanoid 0:3edb3708c8c5 5698 g_MAX5715_device.LDACboutputValue(0);
whismanoid 0:3edb3708c8c5 5699 g_MAX5715_device.LDACboutputValue(1);
whismanoid 0:3edb3708c8c5 5700 break;
whismanoid 0:3edb3708c8c5 5701 case 'H': case 'h': case '1':
whismanoid 0:3edb3708c8c5 5702 g_MAX5715_device.LDACboutputValue(1); // GPIOoutputLDACb(int isLogicHigh);
whismanoid 0:3edb3708c8c5 5703 break;
whismanoid 0:3edb3708c8c5 5704 case 'L': case 'l': case '0':
whismanoid 0:3edb3708c8c5 5705 g_MAX5715_device.LDACboutputValue(0); // GPIOoutputLDACb(int isLogicHigh);
whismanoid 0:3edb3708c8c5 5706 break;
whismanoid 0:3edb3708c8c5 5707 }
whismanoid 0:3edb3708c8c5 5708 }
whismanoid 0:3edb3708c8c5 5709 break;
whismanoid 0:3edb3708c8c5 5710 case 'x': case 'X':
whismanoid 0:3edb3708c8c5 5711 {
whismanoid 0:3edb3708c8c5 5712 }
whismanoid 0:3edb3708c8c5 5713 break;
whismanoid 0:3edb3708c8c5 5714 case 'y': case 'Y':
whismanoid 0:3edb3708c8c5 5715 {
whismanoid 0:3edb3708c8c5 5716 }
whismanoid 0:3edb3708c8c5 5717 break;
whismanoid 0:3edb3708c8c5 5718 case 'z': case 'Z':
whismanoid 0:3edb3708c8c5 5719 {
whismanoid 0:3edb3708c8c5 5720 }
whismanoid 0:3edb3708c8c5 5721 break;
whismanoid 0:3edb3708c8c5 5722 case '~': // TODO: IGNORE_AT_COMMANDS -- ignore ~~~ modem command
whismanoid 0:3edb3708c8c5 5723 {
whismanoid 0:3edb3708c8c5 5724 // TODO: '~' is not recommended for menu commands, interferes with ssh
whismanoid 0:3edb3708c8c5 5725 switch (cmdLine[1])
whismanoid 0:3edb3708c8c5 5726 {
whismanoid 0:3edb3708c8c5 5727 default:
whismanoid 0:3edb3708c8c5 5728 {
whismanoid 0:3edb3708c8c5 5729 #if IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 5730 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 5731 cmdLine_DAPLINKserial.serial().printf("\r\n ignore AT command \"%s\"\r\n",
whismanoid 0:3edb3708c8c5 5732 cmdLine.str());
whismanoid 0:3edb3708c8c5 5733 # endif // HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 5734 #endif // IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 5735 }
whismanoid 0:3edb3708c8c5 5736 }
whismanoid 0:3edb3708c8c5 5737 }
whismanoid 0:3edb3708c8c5 5738 break;
whismanoid 0:3edb3708c8c5 5739 case '+': // TODO: IGNORE_AT_COMMANDS -- ignore +++ modem command
whismanoid 0:3edb3708c8c5 5740 {
whismanoid 0:3edb3708c8c5 5741 #if IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 5742 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 5743 cmdLine_DAPLINKserial.serial().printf("\r\n ignore AT command \"%s\"\r\n", cmdLine.str());
whismanoid 0:3edb3708c8c5 5744 # endif // HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 5745 #endif // IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 5746 }
whismanoid 0:3edb3708c8c5 5747 break;
whismanoid 0:3edb3708c8c5 5748 case '@':
whismanoid 0:3edb3708c8c5 5749 {
whismanoid 0:3edb3708c8c5 5750 // //
whismanoid 0:3edb3708c8c5 5751 // // Menu @ -- print device configuration
whismanoid 0:3edb3708c8c5 5752 // TODO: cmdLine.serial().printf("\r\n @ -- print MAX5715 configuration");
whismanoid 0:3edb3708c8c5 5753 // //
whismanoid 0:3edb3708c8c5 5754 // print shadow register configuration
whismanoid 0:3edb3708c8c5 5755 //
whismanoid 0:3edb3708c8c5 5756 // shadow of write-only register CODE dddd_dddd_dddd_0000
whismanoid 0:3edb3708c8c5 5757 //~ int16_t CMD_1000_CODE;
whismanoid 0:3edb3708c8c5 5758 int index = 0;
whismanoid 0:3edb3708c8c5 5759 for (index = 0; index < 4; index++)
whismanoid 0:3edb3708c8c5 5760 {
whismanoid 0:3edb3708c8c5 5761 cmdLine.serial().printf("CODE %c=0x%4.4x MAX5715_VoltageOfCode(%d)=%5.3fV\r\n",
whismanoid 0:3edb3708c8c5 5762 (char)('A' + index),
whismanoid 0:3edb3708c8c5 5763 (g_MAX5715_device.Shadow_0010_nnnn_CODE[index] & 0xFFFF),
whismanoid 0:3edb3708c8c5 5764 g_MAX5715_device.CODE[index],
whismanoid 0:3edb3708c8c5 5765 g_MAX5715_device.VoltageOfCode(g_MAX5715_device.CODE[index])
whismanoid 0:3edb3708c8c5 5766 );
whismanoid 0:3edb3708c8c5 5767 }
whismanoid 0:3edb3708c8c5 5768 //
whismanoid 0:3edb3708c8c5 5769 cmdLine.serial().printf("\r\n");
whismanoid 0:3edb3708c8c5 5770 //
whismanoid 0:3edb3708c8c5 5771 //
whismanoid 0:3edb3708c8c5 5772 // Menu @) print MAX5715 configuration AND g_MAX5715_device globals
whismanoid 0:3edb3708c8c5 5773 //
whismanoid 0:3edb3708c8c5 5774 #if 1 // SUPPORT_CHANNELS
whismanoid 0:3edb3708c8c5 5775 cmdLine.serial().printf("channelNumber_0_3=%d channels_bitmask_DCBA=%d\r\n",
whismanoid 0:3edb3708c8c5 5776 (g_MAX5715_device.channelNumber_0_3 & 0xFFFF),
whismanoid 0:3edb3708c8c5 5777 (g_MAX5715_device.channels_bitmask_DCBA & 0xFFFF));
whismanoid 0:3edb3708c8c5 5778 #endif // SUPPORT_CHANNELS
whismanoid 0:3edb3708c8c5 5779 //
whismanoid 0:3edb3708c8c5 5780 cmdLine.serial().printf("VRef=%5.3fV\r\n", g_MAX5715_device.VRef);
whismanoid 0:3edb3708c8c5 5781 // dtostrf width and precision: 3.3V / 1024 LSB = 0.00322265625 volts per LSB
whismanoid 0:3edb3708c8c5 5782 }
whismanoid 0:3edb3708c8c5 5783 break;
whismanoid 0:3edb3708c8c5 5784 #endif // APPLICATION_MAX5715
whismanoid 0:3edb3708c8c5 5785
whismanoid 0:3edb3708c8c5 5786 #if APPLICATION_MAX11131 // main_menu_onEOLcommandParser
whismanoid 0:3edb3708c8c5 5787 case '0':
whismanoid 0:3edb3708c8c5 5788 {
whismanoid 0:3edb3708c8c5 5789 // recommended for hex command codes 00..0F
whismanoid 0:3edb3708c8c5 5790 // VERIFY: console menu command 0 int16_t MAX11131_ScanRead(void);
whismanoid 0:3edb3708c8c5 5791 // TODO: cmdLine.serial().printf("\r\n 0 n=? -- MAX11131_ScanRead");
whismanoid 0:3edb3708c8c5 5792 if (cmdLine.parse_uint16_dec("n", g_MAX11131_device.NumWords))
whismanoid 0:3edb3708c8c5 5793 {
whismanoid 0:3edb3708c8c5 5794 }
whismanoid 0:3edb3708c8c5 5795 cmdLine.serial().printf("ScanRead NumWords=%d", g_MAX11131_device.NumWords);
whismanoid 0:3edb3708c8c5 5796 if (g_MAX11131_device.isExternalClock)
whismanoid 0:3edb3708c8c5 5797 {
whismanoid 0:3edb3708c8c5 5798 cmdLine.serial().printf(" External Clock");
whismanoid 0:3edb3708c8c5 5799 //
whismanoid 0:3edb3708c8c5 5800 // Read raw ADC codes from device into AINcode[] and RAW_misoData16[]
whismanoid 0:3edb3708c8c5 5801 // @pre one of the MAX11311_Scan functions was called, setting g_MAX11131_device.NumWords
whismanoid 0:3edb3708c8c5 5802 g_MAX11131_device.ReadAINcode();
whismanoid 0:3edb3708c8c5 5803 // @post RAW_misoData16[index] contains the raw SPI Master-In,Slave-Out data
whismanoid 0:3edb3708c8c5 5804 // @post AINcode[NUM_CHANNELS] contains the latest readings in LSBs
whismanoid 0:3edb3708c8c5 5805 //
whismanoid 0:3edb3708c8c5 5806 AINcode_print_value_externalClock(cmdLine, g_MAX11131_device.NumWords);
whismanoid 0:3edb3708c8c5 5807 }
whismanoid 0:3edb3708c8c5 5808 else
whismanoid 0:3edb3708c8c5 5809 {
whismanoid 0:3edb3708c8c5 5810 cmdLine.serial().printf(" Internal Clock");
whismanoid 0:3edb3708c8c5 5811 //
whismanoid 0:3edb3708c8c5 5812 // Read raw ADC codes from device into AINcode[] and RAW_misoData16[]
whismanoid 0:3edb3708c8c5 5813 // @pre one of the MAX11311_Scan functions was called, setting g_MAX11131_device.NumWords
whismanoid 0:3edb3708c8c5 5814 g_MAX11131_device.ReadAINcode();
whismanoid 0:3edb3708c8c5 5815 // @post RAW_misoData16[index] contains the raw SPI Master-In,Slave-Out data
whismanoid 0:3edb3708c8c5 5816 // @post AINcode[NUM_CHANNELS] contains the latest readings in LSBs
whismanoid 0:3edb3708c8c5 5817 //
whismanoid 0:3edb3708c8c5 5818 AINcode_print_value_chanID(cmdLine, g_MAX11131_device.NumWords);
whismanoid 0:3edb3708c8c5 5819 }
whismanoid 0:3edb3708c8c5 5820 }
whismanoid 0:3edb3708c8c5 5821 break;
whismanoid 0:3edb3708c8c5 5822 case '1':
whismanoid 0:3edb3708c8c5 5823 {
whismanoid 0:3edb3708c8c5 5824 // recommended for hex command codes 10..1F
whismanoid 0:3edb3708c8c5 5825 // VERIFY: console menu command 1 MAX11131_ScanManual(int channelNumber_0_15, int PowerManagement_0_2, int chan_id_0_1);
whismanoid 0:3edb3708c8c5 5826 // TODO: cmdLine.serial().printf("\r\n 1 ch=? pm=? id=? -- MAX11131_ScanManual");
whismanoid 0:3edb3708c8c5 5827 if (cmdLine.parse_byte_dec("ch", g_MAX11131_device.channelNumber_0_15))
whismanoid 0:3edb3708c8c5 5828 {
whismanoid 0:3edb3708c8c5 5829 }
whismanoid 0:3edb3708c8c5 5830 if (cmdLine.parse_byte_dec("pm", g_MAX11131_device.PowerManagement_0_2))
whismanoid 0:3edb3708c8c5 5831 {
whismanoid 0:3edb3708c8c5 5832 }
whismanoid 0:3edb3708c8c5 5833 if (cmdLine.parse_byte_dec("id", g_MAX11131_device.chan_id_0_1))
whismanoid 0:3edb3708c8c5 5834 {
whismanoid 0:3edb3708c8c5 5835 }
whismanoid 0:3edb3708c8c5 5836 cmdLine.serial().printf("ScanManual ch=%d pm=%d id=%d\r\n",
whismanoid 0:3edb3708c8c5 5837 g_MAX11131_device.channelNumber_0_15,
whismanoid 0:3edb3708c8c5 5838 g_MAX11131_device.PowerManagement_0_2,
whismanoid 0:3edb3708c8c5 5839 g_MAX11131_device.chan_id_0_1);
whismanoid 0:3edb3708c8c5 5840 // VERIFY: replace argument with driver global; g_MAX11131_device.PowerManagement_0_2 replaces PowerManagement_0_2
whismanoid 0:3edb3708c8c5 5841 // VERIFY: replace argument with driver global; g_MAX11131_device.chan_id_0_1 replaces chan_id_0_1
whismanoid 0:3edb3708c8c5 5842 // VERIFY: replace argument with driver global; g_MAX11131_device.channelNumber_0_15 replaces channelNumber_0_15
whismanoid 0:3edb3708c8c5 5843 g_MAX11131_device.NumWords = g_MAX11131_device.ScanManual();
whismanoid 0:3edb3708c8c5 5844 //
whismanoid 0:3edb3708c8c5 5845 // Read raw ADC codes from device into AINcode[] and RAW_misoData16[]
whismanoid 0:3edb3708c8c5 5846 // @pre one of the MAX11311_Scan functions was called, setting g_MAX11131_device.NumWords
whismanoid 0:3edb3708c8c5 5847 g_MAX11131_device.ReadAINcode();
whismanoid 0:3edb3708c8c5 5848 // @post RAW_misoData16[index] contains the raw SPI Master-In,Slave-Out data
whismanoid 0:3edb3708c8c5 5849 // @post AINcode[NUM_CHANNELS] contains the latest readings in LSBs
whismanoid 0:3edb3708c8c5 5850 //
whismanoid 0:3edb3708c8c5 5851 AINcode_print_value_externalClock(cmdLine, g_MAX11131_device.NumWords);
whismanoid 0:3edb3708c8c5 5852 }
whismanoid 0:3edb3708c8c5 5853 break;
whismanoid 0:3edb3708c8c5 5854 case '2':
whismanoid 0:3edb3708c8c5 5855 {
whismanoid 0:3edb3708c8c5 5856 // recommended for hex command codes 20..2F
whismanoid 0:3edb3708c8c5 5857 // VERIFY: console menu command 2 int MAX11131_ScanRepeat(uint8_t channelNumber_0_15, uint8_t average_0_4_8_16_32, uint8_t nscan_4_8_12_16, uint8_t PowerManagement_0_2, uint8_t swcnv_0_1);
whismanoid 0:3edb3708c8c5 5858 // TODO: cmdLine.serial().printf("\r\n 2 ch=? av=? n=? pm=? swcnv=? -- MAX11131_ScanRepeat");
whismanoid 0:3edb3708c8c5 5859 // VERIFY: update value of g_MAX11131_device.channelNumber_0_15 from strCommandArgs
whismanoid 0:3edb3708c8c5 5860 // VERIFY: update value of g_MAX11131_device.average_0_4_8_16_32 option from strCommandArgs
whismanoid 0:3edb3708c8c5 5861 // VERIFY: update value of g_MAX11131_device.nscan_4_8_12_16 option from strCommandArgs
whismanoid 0:3edb3708c8c5 5862 // VERIFY: update value of g_MAX11131_device.swcnv_0_1 option from strCommandArgs
whismanoid 0:3edb3708c8c5 5863 // VERIFY: update value of g_MAX11131_device.PowerManagement_0_2 option from strCommandArgs
whismanoid 0:3edb3708c8c5 5864 // VERIFY: parse strCommandArgs for additional arguments including key=value pairs
whismanoid 0:3edb3708c8c5 5865 if (cmdLine.parse_byte_dec("ch", g_MAX11131_device.channelNumber_0_15))
whismanoid 0:3edb3708c8c5 5866 {
whismanoid 0:3edb3708c8c5 5867 }
whismanoid 0:3edb3708c8c5 5868 if (cmdLine.parse_byte_dec("av", g_MAX11131_device.average_0_4_8_16_32))
whismanoid 0:3edb3708c8c5 5869 {
whismanoid 0:3edb3708c8c5 5870 }
whismanoid 0:3edb3708c8c5 5871 if (cmdLine.parse_byte_dec("n", g_MAX11131_device.nscan_4_8_12_16))
whismanoid 0:3edb3708c8c5 5872 {
whismanoid 0:3edb3708c8c5 5873 }
whismanoid 0:3edb3708c8c5 5874 if (cmdLine.parse_byte_dec("swcnv", g_MAX11131_device.swcnv_0_1))
whismanoid 0:3edb3708c8c5 5875 {
whismanoid 0:3edb3708c8c5 5876 }
whismanoid 0:3edb3708c8c5 5877 if (cmdLine.parse_byte_dec("pm", g_MAX11131_device.PowerManagement_0_2))
whismanoid 0:3edb3708c8c5 5878 {
whismanoid 0:3edb3708c8c5 5879 }
whismanoid 0:3edb3708c8c5 5880 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 5881 "ScanRepeat ch=%d average_0_4_8_16_32:%d nscan_4_8_12_16:%d swcnv=%d pm=%d\r\n",
whismanoid 0:3edb3708c8c5 5882 g_MAX11131_device.channelNumber_0_15,
whismanoid 0:3edb3708c8c5 5883 g_MAX11131_device.average_0_4_8_16_32,
whismanoid 0:3edb3708c8c5 5884 g_MAX11131_device.nscan_4_8_12_16,
whismanoid 0:3edb3708c8c5 5885 g_MAX11131_device.swcnv_0_1,
whismanoid 0:3edb3708c8c5 5886 g_MAX11131_device.PowerManagement_0_2);
whismanoid 0:3edb3708c8c5 5887 // VERIFY: replace argument with driver global; g_MAX11131_device.PowerManagement_0_2 replaces PowerManagement_0_2
whismanoid 0:3edb3708c8c5 5888 // VERIFY: replace argument with driver global; g_MAX11131_device.swcnv_0_1 replaces swcnv_0_1
whismanoid 0:3edb3708c8c5 5889 // VERIFY: replace argument with driver global; g_MAX11131_device.nscan_4_8_12_16 replaces nscan_4_8_12_16
whismanoid 0:3edb3708c8c5 5890 // VERIFY: replace argument with driver global; g_MAX11131_device.average_0_4_8_16_32 replaces average_0_4_8_16_32
whismanoid 0:3edb3708c8c5 5891 // VERIFY: replace argument with driver global; g_MAX11131_device.channelNumber_0_15 replaces channelNumber_0_15
whismanoid 0:3edb3708c8c5 5892 g_MAX11131_device.NumWords = g_MAX11131_device.ScanRepeat();
whismanoid 0:3edb3708c8c5 5893 //
whismanoid 0:3edb3708c8c5 5894 // Read raw ADC codes from device into AINcode[] and RAW_misoData16[]
whismanoid 0:3edb3708c8c5 5895 // @pre one of the MAX11311_Scan functions was called, setting g_MAX11131_device.NumWords
whismanoid 0:3edb3708c8c5 5896 g_MAX11131_device.ReadAINcode();
whismanoid 0:3edb3708c8c5 5897 // @post RAW_misoData16[index] contains the raw SPI Master-In,Slave-Out data
whismanoid 0:3edb3708c8c5 5898 // @post AINcode[NUM_CHANNELS] contains the latest readings in LSBs
whismanoid 0:3edb3708c8c5 5899 //
whismanoid 0:3edb3708c8c5 5900 AINcode_print_value_chanID_mean(cmdLine, g_MAX11131_device.NumWords);
whismanoid 0:3edb3708c8c5 5901 }
whismanoid 0:3edb3708c8c5 5902 break;
whismanoid 0:3edb3708c8c5 5903 case '3':
whismanoid 0:3edb3708c8c5 5904 {
whismanoid 0:3edb3708c8c5 5905 // recommended for hex command codes 30..3F
whismanoid 0:3edb3708c8c5 5906 // VERIFY: console menu command 3 MAX11131_ScanStandardInternalClock(int channelNumber_0_15, int average_0_4_8_16_32, int PowerManagement_0_2, int swcnv_0_1);
whismanoid 0:3edb3708c8c5 5907 // TODO: cmdLine.serial().printf("\r\n 3 ch=? av=? pm=? swcnv=? -- MAX11131_ScanStandardIntClock");
whismanoid 0:3edb3708c8c5 5908 // VERIFY: update value of g_MAX11131_device.channelNumber_0_15 from strCommandArgs
whismanoid 0:3edb3708c8c5 5909 // VERIFY: update value of g_MAX11131_device.average_0_4_8_16_32 option from strCommandArgs
whismanoid 0:3edb3708c8c5 5910 // VERIFY: update value of g_MAX11131_device.swcnv_0_1 option from strCommandArgs
whismanoid 0:3edb3708c8c5 5911 // VERIFY: update value of g_MAX11131_device.PowerManagement_0_2 option from strCommandArgs
whismanoid 0:3edb3708c8c5 5912 if (cmdLine.parse_byte_dec("ch", g_MAX11131_device.channelNumber_0_15))
whismanoid 0:3edb3708c8c5 5913 {
whismanoid 0:3edb3708c8c5 5914 }
whismanoid 0:3edb3708c8c5 5915 if (cmdLine.parse_byte_dec("av", g_MAX11131_device.average_0_4_8_16_32))
whismanoid 0:3edb3708c8c5 5916 {
whismanoid 0:3edb3708c8c5 5917 }
whismanoid 0:3edb3708c8c5 5918 if (cmdLine.parse_byte_dec("pm", g_MAX11131_device.PowerManagement_0_2))
whismanoid 0:3edb3708c8c5 5919 {
whismanoid 0:3edb3708c8c5 5920 }
whismanoid 0:3edb3708c8c5 5921 if (cmdLine.parse_byte_dec("swcnv", g_MAX11131_device.swcnv_0_1))
whismanoid 0:3edb3708c8c5 5922 {
whismanoid 0:3edb3708c8c5 5923 }
whismanoid 0:3edb3708c8c5 5924 cmdLine.serial().printf("ScanStandardInternalClock ch=%d average_0_4_8_16_32:%d swcnv=%d pm=%d\r\n",
whismanoid 0:3edb3708c8c5 5925 g_MAX11131_device.channelNumber_0_15,
whismanoid 0:3edb3708c8c5 5926 g_MAX11131_device.average_0_4_8_16_32,
whismanoid 0:3edb3708c8c5 5927 g_MAX11131_device.swcnv_0_1,
whismanoid 0:3edb3708c8c5 5928 g_MAX11131_device.PowerManagement_0_2
whismanoid 0:3edb3708c8c5 5929 );
whismanoid 0:3edb3708c8c5 5930 // VERIFY: replace argument with driver global; g_MAX11131_device.PowerManagement_0_2 replaces PowerManagement_0_2
whismanoid 0:3edb3708c8c5 5931 // VERIFY: replace argument with driver global; g_MAX11131_device.swcnv_0_1 replaces swcnv_0_1
whismanoid 0:3edb3708c8c5 5932 // VERIFY: replace argument with driver global; g_MAX11131_device.average_0_4_8_16_32 replaces average_0_4_8_16_32
whismanoid 0:3edb3708c8c5 5933 // VERIFY: replace argument with driver global; g_MAX11131_device.channelNumber_0_15 replaces channelNumber_0_15
whismanoid 0:3edb3708c8c5 5934 g_MAX11131_device.NumWords = g_MAX11131_device.ScanStandardInternalClock();
whismanoid 0:3edb3708c8c5 5935 //
whismanoid 0:3edb3708c8c5 5936 // Read raw ADC codes from device into AINcode[] and RAW_misoData16[]
whismanoid 0:3edb3708c8c5 5937 // @pre one of the MAX11311_Scan functions was called, setting g_MAX11131_device.NumWords
whismanoid 0:3edb3708c8c5 5938 g_MAX11131_device.ReadAINcode();
whismanoid 0:3edb3708c8c5 5939 // @post RAW_misoData16[index] contains the raw SPI Master-In,Slave-Out data
whismanoid 0:3edb3708c8c5 5940 // @post AINcode[NUM_CHANNELS] contains the latest readings in LSBs
whismanoid 0:3edb3708c8c5 5941 //
whismanoid 0:3edb3708c8c5 5942 AINcode_print_value_chanID(cmdLine, g_MAX11131_device.NumWords);
whismanoid 0:3edb3708c8c5 5943 }
whismanoid 0:3edb3708c8c5 5944 break;
whismanoid 0:3edb3708c8c5 5945 case '4':
whismanoid 0:3edb3708c8c5 5946 {
whismanoid 0:3edb3708c8c5 5947 // recommended for hex command codes 40..4F
whismanoid 0:3edb3708c8c5 5948 // VERIFY: console menu command 4 MAX11131_ScanStandardExternalClock(int channelNumber_0_15, int PowerManagement_0_2, int chan_id_0_1);
whismanoid 0:3edb3708c8c5 5949 // TODO: cmdLine.serial().printf("\r\n 4 ch=? pm=? id=? -- MAX11131_ScanStandardExtClock");
whismanoid 0:3edb3708c8c5 5950 // VERIFY: update value of g_MAX11131_device.channelNumber_0_15 from strCommandArgs
whismanoid 0:3edb3708c8c5 5951 // VERIFY: update value of g_MAX11131_device.PowerManagement_0_2 option from strCommandArgs
whismanoid 0:3edb3708c8c5 5952 // VERIFY: update value of g_MAX11131_device.chan_id_0_1 option from strCommandArgs
whismanoid 0:3edb3708c8c5 5953 if (cmdLine.parse_byte_dec("ch", g_MAX11131_device.channelNumber_0_15))
whismanoid 0:3edb3708c8c5 5954 {
whismanoid 0:3edb3708c8c5 5955 }
whismanoid 0:3edb3708c8c5 5956 if (cmdLine.parse_byte_dec("pm", g_MAX11131_device.PowerManagement_0_2))
whismanoid 0:3edb3708c8c5 5957 {
whismanoid 0:3edb3708c8c5 5958 }
whismanoid 0:3edb3708c8c5 5959 if (cmdLine.parse_byte_dec("id", g_MAX11131_device.chan_id_0_1))
whismanoid 0:3edb3708c8c5 5960 {
whismanoid 0:3edb3708c8c5 5961 }
whismanoid 0:3edb3708c8c5 5962 cmdLine.serial().printf("ScanStandardExternalClock ch=%d pm=%d id=%d\r\n",
whismanoid 0:3edb3708c8c5 5963 g_MAX11131_device.channelNumber_0_15,
whismanoid 0:3edb3708c8c5 5964 g_MAX11131_device.PowerManagement_0_2,
whismanoid 0:3edb3708c8c5 5965 g_MAX11131_device.chan_id_0_1
whismanoid 0:3edb3708c8c5 5966 );
whismanoid 0:3edb3708c8c5 5967 // VERIFY: replace argument with driver global; g_MAX11131_device.PowerManagement_0_2 replaces PowerManagement_0_2
whismanoid 0:3edb3708c8c5 5968 // VERIFY: replace argument with driver global; g_MAX11131_device.chan_id_0_1 replaces chan_id_0_1
whismanoid 0:3edb3708c8c5 5969 // VERIFY: replace argument with driver global; g_MAX11131_device.channelNumber_0_15 replaces channelNumber_0_15
whismanoid 0:3edb3708c8c5 5970 g_MAX11131_device.NumWords = g_MAX11131_device.ScanStandardExternalClock();
whismanoid 0:3edb3708c8c5 5971 //
whismanoid 0:3edb3708c8c5 5972 // Read raw ADC codes from device into AINcode[] and RAW_misoData16[]
whismanoid 0:3edb3708c8c5 5973 // @pre one of the MAX11311_Scan functions was called, setting g_MAX11131_device.NumWords
whismanoid 0:3edb3708c8c5 5974 g_MAX11131_device.ReadAINcode();
whismanoid 0:3edb3708c8c5 5975 // @post RAW_misoData16[index] contains the raw SPI Master-In,Slave-Out data
whismanoid 0:3edb3708c8c5 5976 // @post AINcode[NUM_CHANNELS] contains the latest readings in LSBs
whismanoid 0:3edb3708c8c5 5977 //
whismanoid 0:3edb3708c8c5 5978 AINcode_print_value_externalClock(cmdLine, g_MAX11131_device.NumWords);
whismanoid 0:3edb3708c8c5 5979 }
whismanoid 0:3edb3708c8c5 5980 break;
whismanoid 0:3edb3708c8c5 5981 case '5':
whismanoid 0:3edb3708c8c5 5982 {
whismanoid 0:3edb3708c8c5 5983 // recommended for hex command codes 50..5F
whismanoid 0:3edb3708c8c5 5984 // VERIFY: console menu command 5 MAX11131_ScanUpperInternalClock(int channelNumber_0_15, int average_0_4_8_16_32, int PowerManagement_0_2, int swcnv_0_1);
whismanoid 0:3edb3708c8c5 5985 // TODO: cmdLine.serial().printf("\r\n 5 ch=? av=? pm=? swcnv=? -- MAX11131_ScanUpperIntClock");
whismanoid 0:3edb3708c8c5 5986 // VERIFY: update value of g_MAX11131_device.channelNumber_0_15 from strCommandArgs
whismanoid 0:3edb3708c8c5 5987 // VERIFY: update value of g_MAX11131_device.average_0_4_8_16_32 option from strCommandArgs
whismanoid 0:3edb3708c8c5 5988 // VERIFY: update value of g_MAX11131_device.swcnv_0_1 option from strCommandArgs
whismanoid 0:3edb3708c8c5 5989 // VERIFY: update value of g_MAX11131_device.PowerManagement_0_2 option from strCommandArgs
whismanoid 0:3edb3708c8c5 5990 if (cmdLine.parse_byte_dec("ch", g_MAX11131_device.channelNumber_0_15))
whismanoid 0:3edb3708c8c5 5991 {
whismanoid 0:3edb3708c8c5 5992 }
whismanoid 0:3edb3708c8c5 5993 if (cmdLine.parse_byte_dec("av", g_MAX11131_device.average_0_4_8_16_32))
whismanoid 0:3edb3708c8c5 5994 {
whismanoid 0:3edb3708c8c5 5995 }
whismanoid 0:3edb3708c8c5 5996 if (cmdLine.parse_byte_dec("pm", g_MAX11131_device.PowerManagement_0_2))
whismanoid 0:3edb3708c8c5 5997 {
whismanoid 0:3edb3708c8c5 5998 }
whismanoid 0:3edb3708c8c5 5999 if (cmdLine.parse_byte_dec("swcnv", g_MAX11131_device.swcnv_0_1))
whismanoid 0:3edb3708c8c5 6000 {
whismanoid 0:3edb3708c8c5 6001 }
whismanoid 0:3edb3708c8c5 6002 cmdLine.serial().printf("ScanUpperInternalClock ch=%d average_0_4_8_16_32:%d swcnv=%d pm=%d\r\n",
whismanoid 0:3edb3708c8c5 6003 g_MAX11131_device.channelNumber_0_15,
whismanoid 0:3edb3708c8c5 6004 g_MAX11131_device.average_0_4_8_16_32,
whismanoid 0:3edb3708c8c5 6005 g_MAX11131_device.swcnv_0_1,
whismanoid 0:3edb3708c8c5 6006 g_MAX11131_device.PowerManagement_0_2
whismanoid 0:3edb3708c8c5 6007 );
whismanoid 0:3edb3708c8c5 6008 // VERIFY: replace argument with driver global; g_MAX11131_device.PowerManagement_0_2 replaces PowerManagement_0_2
whismanoid 0:3edb3708c8c5 6009 // VERIFY: replace argument with driver global; g_MAX11131_device.swcnv_0_1 replaces swcnv_0_1
whismanoid 0:3edb3708c8c5 6010 // VERIFY: replace argument with driver global; g_MAX11131_device.average_0_4_8_16_32 replaces average_0_4_8_16_32
whismanoid 0:3edb3708c8c5 6011 // VERIFY: replace argument with driver global; g_MAX11131_device.channelNumber_0_15 replaces channelNumber_0_15
whismanoid 0:3edb3708c8c5 6012 g_MAX11131_device.NumWords = g_MAX11131_device.ScanUpperInternalClock();
whismanoid 0:3edb3708c8c5 6013 //
whismanoid 0:3edb3708c8c5 6014 // Read raw ADC codes from device into AINcode[] and RAW_misoData16[]
whismanoid 0:3edb3708c8c5 6015 // @pre one of the MAX11311_Scan functions was called, setting g_MAX11131_device.NumWords
whismanoid 0:3edb3708c8c5 6016 g_MAX11131_device.ReadAINcode();
whismanoid 0:3edb3708c8c5 6017 // @post RAW_misoData16[index] contains the raw SPI Master-In,Slave-Out data
whismanoid 0:3edb3708c8c5 6018 // @post AINcode[NUM_CHANNELS] contains the latest readings in LSBs
whismanoid 0:3edb3708c8c5 6019 //
whismanoid 0:3edb3708c8c5 6020 AINcode_print_value_chanID(cmdLine, g_MAX11131_device.NumWords);
whismanoid 0:3edb3708c8c5 6021 }
whismanoid 0:3edb3708c8c5 6022 break;
whismanoid 0:3edb3708c8c5 6023 case '6':
whismanoid 0:3edb3708c8c5 6024 {
whismanoid 0:3edb3708c8c5 6025 // recommended for hex command codes 60..6F
whismanoid 0:3edb3708c8c5 6026 // VERIFY: console menu command 6 MAX11131_ScanUpperExternalClock(int channelNumber_0_15, int PowerManagement_0_2, int chan_id_0_1);
whismanoid 0:3edb3708c8c5 6027 // TODO: cmdLine.serial().printf("\r\n 6 ch=? pm=? id=? -- MAX11131_ScanUpperExtClock");
whismanoid 0:3edb3708c8c5 6028 // VERIFY: update value of g_MAX11131_device.channelNumber_0_15 from strCommandArgs
whismanoid 0:3edb3708c8c5 6029 // VERIFY: update value of g_MAX11131_device.PowerManagement_0_2 option from strCommandArgs
whismanoid 0:3edb3708c8c5 6030 // VERIFY: update value of g_MAX11131_device.chan_id_0_1 option from strCommandArgs
whismanoid 0:3edb3708c8c5 6031 if (cmdLine.parse_byte_dec("ch", g_MAX11131_device.channelNumber_0_15))
whismanoid 0:3edb3708c8c5 6032 {
whismanoid 0:3edb3708c8c5 6033 }
whismanoid 0:3edb3708c8c5 6034 if (cmdLine.parse_byte_dec("pm", g_MAX11131_device.PowerManagement_0_2))
whismanoid 0:3edb3708c8c5 6035 {
whismanoid 0:3edb3708c8c5 6036 }
whismanoid 0:3edb3708c8c5 6037 if (cmdLine.parse_byte_dec("id", g_MAX11131_device.chan_id_0_1))
whismanoid 0:3edb3708c8c5 6038 {
whismanoid 0:3edb3708c8c5 6039 }
whismanoid 0:3edb3708c8c5 6040 cmdLine.serial().printf("ScanUpperExternalClock ch=%d pm=%d id=%d\r\n",
whismanoid 0:3edb3708c8c5 6041 g_MAX11131_device.channelNumber_0_15,
whismanoid 0:3edb3708c8c5 6042 g_MAX11131_device.PowerManagement_0_2,
whismanoid 0:3edb3708c8c5 6043 g_MAX11131_device.chan_id_0_1
whismanoid 0:3edb3708c8c5 6044 );
whismanoid 0:3edb3708c8c5 6045 // VERIFY: replace argument with driver global; g_MAX11131_device.PowerManagement_0_2 replaces PowerManagement_0_2
whismanoid 0:3edb3708c8c5 6046 // VERIFY: replace argument with driver global; g_MAX11131_device.chan_id_0_1 replaces chan_id_0_1
whismanoid 0:3edb3708c8c5 6047 // VERIFY: replace argument with driver global; g_MAX11131_device.channelNumber_0_15 replaces channelNumber_0_15
whismanoid 0:3edb3708c8c5 6048 g_MAX11131_device.NumWords = g_MAX11131_device.ScanUpperExternalClock();
whismanoid 0:3edb3708c8c5 6049 //
whismanoid 0:3edb3708c8c5 6050 // Read raw ADC codes from device into AINcode[] and RAW_misoData16[]
whismanoid 0:3edb3708c8c5 6051 // @pre one of the MAX11311_Scan functions was called, setting g_MAX11131_device.NumWords
whismanoid 0:3edb3708c8c5 6052 g_MAX11131_device.ReadAINcode();
whismanoid 0:3edb3708c8c5 6053 // @post RAW_misoData16[index] contains the raw SPI Master-In,Slave-Out data
whismanoid 0:3edb3708c8c5 6054 // @post AINcode[NUM_CHANNELS] contains the latest readings in LSBs
whismanoid 0:3edb3708c8c5 6055 //
whismanoid 0:3edb3708c8c5 6056 AINcode_print_value_externalClock(cmdLine, g_MAX11131_device.NumWords);
whismanoid 0:3edb3708c8c5 6057 }
whismanoid 0:3edb3708c8c5 6058 break;
whismanoid 0:3edb3708c8c5 6059 case '7':
whismanoid 0:3edb3708c8c5 6060 {
whismanoid 0:3edb3708c8c5 6061 // recommended for hex command codes 70..7F
whismanoid 0:3edb3708c8c5 6062 // VERIFY: console menu command 7 MAX11131_ScanCustomInternalClock(int16_t enabledChannelsMask, int average_0_4_8_16_32, int PowerManagement_0_2, int swcnv_0_1);
whismanoid 0:3edb3708c8c5 6063 // TODO: cmdLine.serial().printf("\r\n 7 enableMask=0xffff av=? pm=? swcnv=? -- MAX11131_ScanCustomIntClock");
whismanoid 0:3edb3708c8c5 6064 // VERIFY: update value of g_MAX11131_device.average_0_4_8_16_32 option from strCommandArgs
whismanoid 0:3edb3708c8c5 6065 // VERIFY: update value of g_MAX11131_device.swcnv_0_1 option from strCommandArgs
whismanoid 0:3edb3708c8c5 6066 // VERIFY: update value of g_MAX11131_device.PowerManagement_0_2 option from strCommandArgs
whismanoid 0:3edb3708c8c5 6067 if (cmdLine.parse_int16_hex("enableMask", g_MAX11131_device.enabledChannelsMask))
whismanoid 0:3edb3708c8c5 6068 {
whismanoid 0:3edb3708c8c5 6069 // TODO1: get g_MAX11131_device.enabledChannelsMask from strCommandArgs
whismanoid 0:3edb3708c8c5 6070 }
whismanoid 0:3edb3708c8c5 6071 if (cmdLine.parse_byte_dec("av", g_MAX11131_device.average_0_4_8_16_32))
whismanoid 0:3edb3708c8c5 6072 {
whismanoid 0:3edb3708c8c5 6073 }
whismanoid 0:3edb3708c8c5 6074 if (cmdLine.parse_byte_dec("pm", g_MAX11131_device.PowerManagement_0_2))
whismanoid 0:3edb3708c8c5 6075 {
whismanoid 0:3edb3708c8c5 6076 }
whismanoid 0:3edb3708c8c5 6077 if (cmdLine.parse_byte_dec("swcnv", g_MAX11131_device.swcnv_0_1))
whismanoid 0:3edb3708c8c5 6078 {
whismanoid 0:3edb3708c8c5 6079 }
whismanoid 0:3edb3708c8c5 6080 cmdLine.serial().printf(
whismanoid 0:3edb3708c8c5 6081 "ScanCustomInternalClock enabledChannelsMask:0x%4.4x average_0_4_8_16_32:%d pm=%d swcnv=%d\r\n",
whismanoid 0:3edb3708c8c5 6082 (g_MAX11131_device.enabledChannelsMask & 0xFFFF),
whismanoid 0:3edb3708c8c5 6083 g_MAX11131_device.average_0_4_8_16_32,
whismanoid 0:3edb3708c8c5 6084 g_MAX11131_device.PowerManagement_0_2,
whismanoid 0:3edb3708c8c5 6085 g_MAX11131_device.swcnv_0_1
whismanoid 0:3edb3708c8c5 6086 );
whismanoid 0:3edb3708c8c5 6087 // VERIFY: replace argument with driver global; g_MAX11131_device.PowerManagement_0_2 replaces PowerManagement_0_2
whismanoid 0:3edb3708c8c5 6088 // VERIFY: replace argument with driver global; g_MAX11131_device.swcnv_0_1 replaces swcnv_0_1
whismanoid 0:3edb3708c8c5 6089 // VERIFY: replace argument with driver global; g_MAX11131_device.average_0_4_8_16_32 replaces average_0_4_8_16_32
whismanoid 0:3edb3708c8c5 6090 // VERIFY: replace argument with driver global; g_MAX11131_device.enabledChannelsMask replaces enabledChannelsMask
whismanoid 0:3edb3708c8c5 6091 g_MAX11131_device.NumWords = g_MAX11131_device.ScanCustomInternalClock();
whismanoid 0:3edb3708c8c5 6092 //
whismanoid 0:3edb3708c8c5 6093 // Read raw ADC codes from device into AINcode[] and RAW_misoData16[]
whismanoid 0:3edb3708c8c5 6094 // @pre one of the MAX11311_Scan functions was called, setting g_MAX11131_device.NumWords
whismanoid 0:3edb3708c8c5 6095 g_MAX11131_device.ReadAINcode();
whismanoid 0:3edb3708c8c5 6096 // @post RAW_misoData16[index] contains the raw SPI Master-In,Slave-Out data
whismanoid 0:3edb3708c8c5 6097 // @post AINcode[NUM_CHANNELS] contains the latest readings in LSBs
whismanoid 0:3edb3708c8c5 6098 //
whismanoid 0:3edb3708c8c5 6099 AINcode_print_value_chanID(cmdLine, g_MAX11131_device.NumWords);
whismanoid 0:3edb3708c8c5 6100 }
whismanoid 0:3edb3708c8c5 6101 break;
whismanoid 0:3edb3708c8c5 6102 case '8':
whismanoid 0:3edb3708c8c5 6103 {
whismanoid 0:3edb3708c8c5 6104 // recommended for hex command codes 80..8F
whismanoid 0:3edb3708c8c5 6105 // VERIFY: console menu command 8 MAX11131_ScanCustomExternalClock(int16_t enabledChannelsMask, int PowerManagement_0_2, int chan_id_0_1);
whismanoid 0:3edb3708c8c5 6106 // TODO: cmdLine.serial().printf("\r\n 8 enableMask=0xffff pm=0 id=1 -- MAX11131_ScanCustomExtClock");
whismanoid 0:3edb3708c8c5 6107 if (cmdLine.parse_int16_hex("enableMask", g_MAX11131_device.enabledChannelsMask))
whismanoid 0:3edb3708c8c5 6108 {
whismanoid 0:3edb3708c8c5 6109 // TODO1: get g_MAX11131_device.enabledChannelsMask from strCommandArgs
whismanoid 0:3edb3708c8c5 6110 }
whismanoid 0:3edb3708c8c5 6111 if (cmdLine.parse_byte_dec("pm", g_MAX11131_device.PowerManagement_0_2))
whismanoid 0:3edb3708c8c5 6112 {
whismanoid 0:3edb3708c8c5 6113 }
whismanoid 0:3edb3708c8c5 6114 if (cmdLine.parse_byte_dec("id", g_MAX11131_device.chan_id_0_1))
whismanoid 0:3edb3708c8c5 6115 {
whismanoid 0:3edb3708c8c5 6116 }
whismanoid 0:3edb3708c8c5 6117 cmdLine.serial().printf("ScanCustomExternalClock enabledChannelsMask:0x%4.4x pm=%d id=%d\r\n",
whismanoid 0:3edb3708c8c5 6118 (g_MAX11131_device.enabledChannelsMask & 0xFFFF),
whismanoid 0:3edb3708c8c5 6119 g_MAX11131_device.PowerManagement_0_2,
whismanoid 0:3edb3708c8c5 6120 g_MAX11131_device.chan_id_0_1
whismanoid 0:3edb3708c8c5 6121 );
whismanoid 0:3edb3708c8c5 6122 // VERIFY: replace argument with driver global; g_MAX11131_device.PowerManagement_0_2 replaces PowerManagement_0_2
whismanoid 0:3edb3708c8c5 6123 // VERIFY: replace argument with driver global; g_MAX11131_device.chan_id_0_1 replaces chan_id_0_1
whismanoid 0:3edb3708c8c5 6124 // VERIFY: replace argument with driver global; g_MAX11131_device.enabledChannelsMask replaces enabledChannelsMask
whismanoid 0:3edb3708c8c5 6125 g_MAX11131_device.NumWords = g_MAX11131_device.ScanCustomExternalClock();
whismanoid 0:3edb3708c8c5 6126 //
whismanoid 0:3edb3708c8c5 6127 // Read raw ADC codes from device into AINcode[] and RAW_misoData16[]
whismanoid 0:3edb3708c8c5 6128 // @pre one of the MAX11311_Scan functions was called, setting g_MAX11131_device.NumWords
whismanoid 0:3edb3708c8c5 6129 g_MAX11131_device.ReadAINcode();
whismanoid 0:3edb3708c8c5 6130 // @post RAW_misoData16[index] contains the raw SPI Master-In,Slave-Out data
whismanoid 0:3edb3708c8c5 6131 // @post AINcode[NUM_CHANNELS] contains the latest readings in LSBs
whismanoid 0:3edb3708c8c5 6132 //
whismanoid 0:3edb3708c8c5 6133 AINcode_print_value_externalClock(cmdLine, g_MAX11131_device.NumWords);
whismanoid 0:3edb3708c8c5 6134 }
whismanoid 0:3edb3708c8c5 6135 break;
whismanoid 0:3edb3708c8c5 6136 case '9':
whismanoid 0:3edb3708c8c5 6137 {
whismanoid 0:3edb3708c8c5 6138 // recommended for hex command codes 90..9F
whismanoid 0:3edb3708c8c5 6139 // VERIFY: console menu command 9 MAX11131_ScanSampleSetExternalClock(uint8_t enabledChannelsPatternLength_1_256, int16_t enabledChannelsPattern[], int PowerManagement_0_2, int chan_id_0_1);
whismanoid 0:3edb3708c8c5 6140 // TODO: cmdLine.serial().printf("\r\n 9 channelsPattern... pm=? id=? | len=? -- MAX11131_ScanSampleSetExtClock");
whismanoid 0:3edb3708c8c5 6141 //
whismanoid 0:3edb3708c8c5 6142 // get MAX11131 Sampleset channel selection pattern parse_strCommandArgs(strCommandArgs);
whismanoid 0:3edb3708c8c5 6143 // cmdLine.parse_byteCount_byteList_dec(byteCount, mosiData, MAX_SPI_BYTE_COUNT)
whismanoid 0:3edb3708c8c5 6144 // into g_MAX11131_device.enabledChannelsPatternLength_1_256
whismanoid 0:3edb3708c8c5 6145 // into g_MAX11131_device.enabledChannelsPattern[0..255]
whismanoid 0:3edb3708c8c5 6146 size_t numValues;
whismanoid 0:3edb3708c8c5 6147 char valueList[256];
whismanoid 0:3edb3708c8c5 6148 if (cmdLine.parse_byteCount_byteList_dec( numValues, valueList, 256))
whismanoid 0:3edb3708c8c5 6149 {
whismanoid 0:3edb3708c8c5 6150 // first value is the "9" command itself
whismanoid 0:3edb3708c8c5 6151 g_MAX11131_device.enabledChannelsPatternLength_1_256 = numValues - 1;
whismanoid 0:3edb3708c8c5 6152 // copy valueList[1, ...] into g_MAX11131_device.enabledChannelsPattern[0, ...]
whismanoid 0:3edb3708c8c5 6153 for (size_t index = 0; index < (numValues - 1); index++)
whismanoid 0:3edb3708c8c5 6154 {
whismanoid 0:3edb3708c8c5 6155 g_MAX11131_device.enabledChannelsPattern[index] = valueList[1 + index];
whismanoid 0:3edb3708c8c5 6156 }
whismanoid 0:3edb3708c8c5 6157 }
whismanoid 0:3edb3708c8c5 6158 //
whismanoid 0:3edb3708c8c5 6159 cmdLine.serial().printf("ScanSampleSetExternalClock enabledChannelsPattern:{ ");
whismanoid 0:3edb3708c8c5 6160 int index;
whismanoid 0:3edb3708c8c5 6161 for (index = 0; index < g_MAX11131_device.enabledChannelsPatternLength_1_256; index++)
whismanoid 0:3edb3708c8c5 6162 {
whismanoid 0:3edb3708c8c5 6163 //~ Serial.print( ((g_enabledChannelsPattern[index] >> 4) & 0x000F), DEC);
whismanoid 0:3edb3708c8c5 6164 //~ Serial.print(" ");
whismanoid 0:3edb3708c8c5 6165 cmdLine.serial().printf("AIN%d ", ((g_MAX11131_device.enabledChannelsPattern[index]) & 0x000F));
whismanoid 0:3edb3708c8c5 6166 }
whismanoid 0:3edb3708c8c5 6167 cmdLine.serial().printf("}");
whismanoid 0:3edb3708c8c5 6168 cmdLine.serial().printf(" pm=%d id=%d\r\n", g_MAX11131_device.PowerManagement_0_2,
whismanoid 0:3edb3708c8c5 6169 g_MAX11131_device.chan_id_0_1);
whismanoid 0:3edb3708c8c5 6170 // VERIFY: replace argument with driver global; g_MAX11131_device.PowerManagement_0_2 replaces PowerManagement_0_2
whismanoid 0:3edb3708c8c5 6171 // VERIFY: replace argument with driver global; g_MAX11131_device.chan_id_0_1 replaces chan_id_0_1
whismanoid 0:3edb3708c8c5 6172 g_MAX11131_device.NumWords = g_MAX11131_device.ScanSampleSetExternalClock();
whismanoid 0:3edb3708c8c5 6173 //
whismanoid 0:3edb3708c8c5 6174 // Read raw ADC codes from device into AINcode[] and RAW_misoData16[]
whismanoid 0:3edb3708c8c5 6175 // @pre one of the MAX11311_Scan functions was called, setting g_MAX11131_device.NumWords
whismanoid 0:3edb3708c8c5 6176 g_MAX11131_device.ReadAINcode();
whismanoid 0:3edb3708c8c5 6177 // @post RAW_misoData16[index] contains the raw SPI Master-In,Slave-Out data
whismanoid 0:3edb3708c8c5 6178 // @post AINcode[NUM_CHANNELS] contains the latest readings in LSBs
whismanoid 0:3edb3708c8c5 6179 //
whismanoid 0:3edb3708c8c5 6180 AINcode_print_value_externalClock(cmdLine, g_MAX11131_device.NumWords);
whismanoid 0:3edb3708c8c5 6181 }
whismanoid 0:3edb3708c8c5 6182 break;
whismanoid 0:3edb3708c8c5 6183 case 'a': case 'A':
whismanoid 0:3edb3708c8c5 6184 {
whismanoid 0:3edb3708c8c5 6185 // recommended for hex command codes A0..AF
whismanoid 0:3edb3708c8c5 6186 switch (cmdLine[1])
whismanoid 0:3edb3708c8c5 6187 {
whismanoid 0:3edb3708c8c5 6188 case 't': case 'T':
whismanoid 0:3edb3708c8c5 6189 #if IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6190 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6191 cmdLine_DAPLINKserial.serial().printf("\r\n ignore AT command \"%s\"\r\n", cmdLine.str());
whismanoid 0:3edb3708c8c5 6192 # endif // HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6193 // AT command: skip the prompt to avoid confusing modem detector
whismanoid 0:3edb3708c8c5 6194 return;
whismanoid 0:3edb3708c8c5 6195 #endif // IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6196 }
whismanoid 0:3edb3708c8c5 6197 }
whismanoid 0:3edb3708c8c5 6198 break;
whismanoid 0:3edb3708c8c5 6199 case 'b': case 'B':
whismanoid 0:3edb3708c8c5 6200 {
whismanoid 0:3edb3708c8c5 6201 // recommended for hex command codes B0..BF
whismanoid 0:3edb3708c8c5 6202 }
whismanoid 0:3edb3708c8c5 6203 break;
whismanoid 0:3edb3708c8c5 6204 case 'c': case 'C':
whismanoid 0:3edb3708c8c5 6205 {
whismanoid 0:3edb3708c8c5 6206 // recommended for hex command codes C0..CF
whismanoid 0:3edb3708c8c5 6207 }
whismanoid 0:3edb3708c8c5 6208 break;
whismanoid 0:3edb3708c8c5 6209 case 'd': case 'D':
whismanoid 0:3edb3708c8c5 6210 {
whismanoid 0:3edb3708c8c5 6211 // recommended for hex command codes D0..DF
whismanoid 0:3edb3708c8c5 6212 }
whismanoid 0:3edb3708c8c5 6213 break;
whismanoid 0:3edb3708c8c5 6214 case 'e': case 'E':
whismanoid 0:3edb3708c8c5 6215 {
whismanoid 0:3edb3708c8c5 6216 // recommended for hex command codes E0..EF
whismanoid 0:3edb3708c8c5 6217 }
whismanoid 0:3edb3708c8c5 6218 break;
whismanoid 0:3edb3708c8c5 6219 case 'f': case 'F':
whismanoid 0:3edb3708c8c5 6220 {
whismanoid 0:3edb3708c8c5 6221 // recommended for hex command codes F0..FF
whismanoid 0:3edb3708c8c5 6222 }
whismanoid 0:3edb3708c8c5 6223 break;
whismanoid 0:3edb3708c8c5 6224 case 'x': case 'X':
whismanoid 0:3edb3708c8c5 6225 {
whismanoid 0:3edb3708c8c5 6226 }
whismanoid 0:3edb3708c8c5 6227 break;
whismanoid 0:3edb3708c8c5 6228 case 'y': case 'Y':
whismanoid 0:3edb3708c8c5 6229 {
whismanoid 0:3edb3708c8c5 6230 }
whismanoid 0:3edb3708c8c5 6231 break;
whismanoid 0:3edb3708c8c5 6232 case 'i': case 'I':
whismanoid 0:3edb3708c8c5 6233 {
whismanoid 0:3edb3708c8c5 6234 // TODO: cmdLine.serial().printf("\r\n ISc) IUc) IBc) IRc) reconfigure channel single-ended/unipolar/bipolar/range");
whismanoid 0:3edb3708c8c5 6235 char strChannelId[3];
whismanoid 0:3edb3708c8c5 6236 strChannelId[0] = cmdLine[2];
whismanoid 0:3edb3708c8c5 6237 strChannelId[1] = cmdLine[3];
whismanoid 0:3edb3708c8c5 6238 strChannelId[2] = '\0';
whismanoid 0:3edb3708c8c5 6239 int channelId_0_15 = strtoul(strChannelId, NULL, 10); // strtol(str, NULL, 10): get decimal value
whismanoid 0:3edb3708c8c5 6240 switch (cmdLine[1])
whismanoid 0:3edb3708c8c5 6241 {
whismanoid 0:3edb3708c8c5 6242 case 's': case 'S':
whismanoid 0:3edb3708c8c5 6243 g_MAX11131_device.Reconfigure_SingleEnded(channelId_0_15);
whismanoid 0:3edb3708c8c5 6244 break;
whismanoid 0:3edb3708c8c5 6245 case 'u': case 'U':
whismanoid 0:3edb3708c8c5 6246 g_MAX11131_device.Reconfigure_DifferentialUnipolar(channelId_0_15);
whismanoid 0:3edb3708c8c5 6247 break;
whismanoid 0:3edb3708c8c5 6248 case 'b': case 'B':
whismanoid 0:3edb3708c8c5 6249 g_MAX11131_device.Reconfigure_DifferentialBipolarFSVref(channelId_0_15);
whismanoid 0:3edb3708c8c5 6250 break;
whismanoid 0:3edb3708c8c5 6251 case 'r': case 'R':
whismanoid 0:3edb3708c8c5 6252 g_MAX11131_device.Reconfigure_DifferentialBipolarFS2Vref(channelId_0_15);
whismanoid 0:3edb3708c8c5 6253 break;
whismanoid 0:3edb3708c8c5 6254 }
whismanoid 0:3edb3708c8c5 6255 // char cmd1 = strCommandArgs[0];
whismanoid 0:3edb3708c8c5 6256 // strCommandArgs.remove(0, 1); // unsigned int index, unsigned int count
whismanoid 0:3edb3708c8c5 6257 // // get argument int channelId_0_15
whismanoid 0:3edb3708c8c5 6258 // // parse_strCommandArgs(strCommandArgs);
whismanoid 0:3edb3708c8c5 6259 // int channelId_0_15 = strtoul(strCommandArgs.c_str(), NULL, 10); // strtol(str, NULL, 10): get decimal value
whismanoid 0:3edb3708c8c5 6260 // if (cmd1 == 'S') {
whismanoid 0:3edb3708c8c5 6261 // MAX11131_Reconfigure_SingleEnded(channelId_0_15);
whismanoid 0:3edb3708c8c5 6262 // }
whismanoid 0:3edb3708c8c5 6263 // else if (cmd1 == 'U') {
whismanoid 0:3edb3708c8c5 6264 // MAX11131_Reconfigure_DifferentialUnipolar(channelId_0_15);
whismanoid 0:3edb3708c8c5 6265 // }
whismanoid 0:3edb3708c8c5 6266 // else if (cmd1 == 'B') {
whismanoid 0:3edb3708c8c5 6267 // MAX11131_Reconfigure_DifferentialBipolarFSVref(channelId_0_15);
whismanoid 0:3edb3708c8c5 6268 // }
whismanoid 0:3edb3708c8c5 6269 // else if (cmd1 == 'R') {
whismanoid 0:3edb3708c8c5 6270 // MAX11131_Reconfigure_DifferentialBipolarFS2Vref(channelId_0_15);
whismanoid 0:3edb3708c8c5 6271 // }
whismanoid 0:3edb3708c8c5 6272 }
whismanoid 0:3edb3708c8c5 6273 break;
whismanoid 0:3edb3708c8c5 6274 case '@':
whismanoid 0:3edb3708c8c5 6275 {
whismanoid 0:3edb3708c8c5 6276 // TODO: cmdLine.serial().printf("\r\n @ -- print MAX11131 configuration");
whismanoid 0:3edb3708c8c5 6277 // print shadow register configuration
whismanoid 0:3edb3708c8c5 6278 //
whismanoid 0:3edb3708c8c5 6279 cmdLine.serial().printf("0x%4.4x", (g_MAX11131_device.ADC_MODE_CONTROL & 0xFFFF));
whismanoid 0:3edb3708c8c5 6280 MAX11131_print_register_verbose(cmdLine, g_MAX11131_device.ADC_MODE_CONTROL);
whismanoid 0:3edb3708c8c5 6281 cmdLine.serial().printf("0x%4.4x", (g_MAX11131_device.ADC_CONFIGURATION & 0xFFFF));
whismanoid 0:3edb3708c8c5 6282 MAX11131_print_register_verbose(cmdLine, g_MAX11131_device.ADC_CONFIGURATION);
whismanoid 0:3edb3708c8c5 6283 cmdLine.serial().printf("0x%4.4x", (g_MAX11131_device.UNIPOLAR & 0xFFFF));
whismanoid 0:3edb3708c8c5 6284 MAX11131_print_register_verbose(cmdLine, g_MAX11131_device.UNIPOLAR);
whismanoid 0:3edb3708c8c5 6285 cmdLine.serial().printf("0x%4.4x", (g_MAX11131_device.BIPOLAR & 0xFFFF));
whismanoid 0:3edb3708c8c5 6286 MAX11131_print_register_verbose(cmdLine, g_MAX11131_device.BIPOLAR);
whismanoid 0:3edb3708c8c5 6287 cmdLine.serial().printf("0x%4.4x", (g_MAX11131_device.RANGE & 0xFFFF));
whismanoid 0:3edb3708c8c5 6288 MAX11131_print_register_verbose(cmdLine, g_MAX11131_device.RANGE);
whismanoid 0:3edb3708c8c5 6289 cmdLine.serial().printf("0x%4.4x", (g_MAX11131_device.CSCAN0 & 0xFFFF));
whismanoid 0:3edb3708c8c5 6290 MAX11131_print_register_verbose(cmdLine, g_MAX11131_device.CSCAN0);
whismanoid 0:3edb3708c8c5 6291 cmdLine.serial().printf("0x%4.4x", (g_MAX11131_device.CSCAN1 & 0xFFFF));
whismanoid 0:3edb3708c8c5 6292 MAX11131_print_register_verbose(cmdLine, g_MAX11131_device.CSCAN1);
whismanoid 0:3edb3708c8c5 6293 cmdLine.serial().printf("0x%4.4x", (g_MAX11131_device.SAMPLESET & 0xFFFF));
whismanoid 0:3edb3708c8c5 6294 MAX11131_print_register_verbose(cmdLine, g_MAX11131_device.SAMPLESET);
whismanoid 0:3edb3708c8c5 6295 //
whismanoid 0:3edb3708c8c5 6296 // VERIFY: print shadow SAMPLESET pattern entry
whismanoid 0:3edb3708c8c5 6297 int entryIndex;
whismanoid 0:3edb3708c8c5 6298 for (entryIndex = 0; entryIndex < g_MAX11131_device.enabledChannelsPatternLength_1_256;
whismanoid 0:3edb3708c8c5 6299 entryIndex += 4)
whismanoid 0:3edb3708c8c5 6300 {
whismanoid 0:3edb3708c8c5 6301 uint16_t pack4channels = 0;
whismanoid 0:3edb3708c8c5 6302 pack4channels |= (((g_MAX11131_device.enabledChannelsPattern[entryIndex + 0]) & 0x0F) << 12);
whismanoid 0:3edb3708c8c5 6303 if ((entryIndex + 1) < g_MAX11131_device.enabledChannelsPatternLength_1_256) {
whismanoid 0:3edb3708c8c5 6304 pack4channels |= (((g_MAX11131_device.enabledChannelsPattern[entryIndex + 1]) & 0x0F) << 8);
whismanoid 0:3edb3708c8c5 6305 }
whismanoid 0:3edb3708c8c5 6306 if ((entryIndex + 2) < g_MAX11131_device.enabledChannelsPatternLength_1_256) {
whismanoid 0:3edb3708c8c5 6307 pack4channels |= (((g_MAX11131_device.enabledChannelsPattern[entryIndex + 2]) & 0x0F) << 4);
whismanoid 0:3edb3708c8c5 6308 }
whismanoid 0:3edb3708c8c5 6309 if ((entryIndex + 3) < g_MAX11131_device.enabledChannelsPatternLength_1_256) {
whismanoid 0:3edb3708c8c5 6310 pack4channels |= ((g_MAX11131_device.enabledChannelsPattern[entryIndex + 3]) & 0x0F);
whismanoid 0:3edb3708c8c5 6311 }
whismanoid 0:3edb3708c8c5 6312 //~ SPIwrite16bits(pack4channels);
whismanoid 0:3edb3708c8c5 6313 cmdLine.serial().printf(" 0x%4.4x", (pack4channels & 0xFFFF));
whismanoid 0:3edb3708c8c5 6314 // decode SAMPLESET channel select pattern
whismanoid 0:3edb3708c8c5 6315 cmdLine.serial().printf(" SampleSet Entry: AIN%d AIN%d AIN%d AIN%d\r\n",
whismanoid 0:3edb3708c8c5 6316 ((pack4channels >> 12) & 0x000F),
whismanoid 0:3edb3708c8c5 6317 ((pack4channels >> 8) & 0x000F),
whismanoid 0:3edb3708c8c5 6318 ((pack4channels >> 4) & 0x000F),
whismanoid 0:3edb3708c8c5 6319 ((pack4channels ) & 0x000F)
whismanoid 0:3edb3708c8c5 6320 );
whismanoid 0:3edb3708c8c5 6321 }
whismanoid 0:3edb3708c8c5 6322 //cmdLine.serial().printf(" SAMPLESET enabledChannelsPattern:{ ");
whismanoid 0:3edb3708c8c5 6323 //int index;
whismanoid 0:3edb3708c8c5 6324 //for (index = 0; index < g_MAX11131_device.enabledChannelsPatternLength_1_256; index++)
whismanoid 0:3edb3708c8c5 6325 //{
whismanoid 0:3edb3708c8c5 6326 // //~ cmdLine.serial().printf( ((g_enabledChannelsPattern[index] >> 4) & 0x000F), DEC);
whismanoid 0:3edb3708c8c5 6327 // //~ cmdLine.serial().printf(" ");
whismanoid 0:3edb3708c8c5 6328 // cmdLine.serial().printf("AIN");
whismanoid 0:3edb3708c8c5 6329 // cmdLine.serial().printf( ((g_MAX11131_device.enabledChannelsPattern[index]) & 0x000F), DEC);
whismanoid 0:3edb3708c8c5 6330 // cmdLine.serial().printf(" ");
whismanoid 0:3edb3708c8c5 6331 //}
whismanoid 0:3edb3708c8c5 6332 //cmdLine.serial().printf("}");
whismanoid 0:3edb3708c8c5 6333 //
whismanoid 0:3edb3708c8c5 6334 // Menu @) print MAX11131 configuration AND g_MAX11131_device globals
whismanoid 0:3edb3708c8c5 6335 //
whismanoid 0:3edb3708c8c5 6336 cmdLine.serial().printf("SPI_MOSI_Semantic=%d\r\n", (g_MAX11131_device.SPI_MOSI_Semantic & 0xFFFF));
whismanoid 0:3edb3708c8c5 6337 cmdLine.serial().printf("NumWords=%d\r\n", (g_MAX11131_device.NumWords & 0xFFFF));
whismanoid 0:3edb3708c8c5 6338 cmdLine.serial().printf("isExternalClock=%d\r\n", (g_MAX11131_device.isExternalClock & 0xFFFF));
whismanoid 0:3edb3708c8c5 6339 cmdLine.serial().printf("ScanMode=%d\r\n", (g_MAX11131_device.ScanMode & 0xFFFF));
whismanoid 0:3edb3708c8c5 6340 cmdLine.serial().printf("channelNumber_0_15=%d\r\n",
whismanoid 0:3edb3708c8c5 6341 (g_MAX11131_device.channelNumber_0_15 & 0xFFFF));
whismanoid 0:3edb3708c8c5 6342 cmdLine.serial().printf("PowerManagement_0_2=%d\r\n",
whismanoid 0:3edb3708c8c5 6343 (g_MAX11131_device.PowerManagement_0_2 & 0xFFFF));
whismanoid 0:3edb3708c8c5 6344 cmdLine.serial().printf("chan_id_0_1=%d\r\n", (g_MAX11131_device.chan_id_0_1 & 0xFFFF));
whismanoid 0:3edb3708c8c5 6345 cmdLine.serial().printf("average_0_4_8_16_32=%d\r\n",
whismanoid 0:3edb3708c8c5 6346 (g_MAX11131_device.average_0_4_8_16_32 & 0xFFFF));
whismanoid 0:3edb3708c8c5 6347 cmdLine.serial().printf("nscan_4_8_12_16=%d\r\n", (g_MAX11131_device.nscan_4_8_12_16 & 0xFFFF));
whismanoid 0:3edb3708c8c5 6348 cmdLine.serial().printf("swcnv_0_1=%d\r\n", (g_MAX11131_device.swcnv_0_1 & 0xFFFF));
whismanoid 0:3edb3708c8c5 6349 cmdLine.serial().printf("enabledChannelsMask=0x%4.4x\r\n",
whismanoid 0:3edb3708c8c5 6350 (g_MAX11131_device.enabledChannelsMask & 0xFFFF));
whismanoid 0:3edb3708c8c5 6351 //
whismanoid 0:3edb3708c8c5 6352 cmdLine.serial().printf("VRef=%5.3fV\r\n", g_MAX11131_device.VRef);
whismanoid 0:3edb3708c8c5 6353 // dtostrf width and precision: 3.3V / 1024 LSB = 0.00322265625 volts per LSB
whismanoid 0:3edb3708c8c5 6354 //
whismanoid 0:3edb3708c8c5 6355 }
whismanoid 0:3edb3708c8c5 6356 //case '&':
whismanoid 0:3edb3708c8c5 6357 //{
whismanoid 0:3edb3708c8c5 6358 // // TODO: cmdLine.serial().printf("\r\n & -- MAX11131_Example_ScanManual");
whismanoid 0:3edb3708c8c5 6359 //}
whismanoid 0:3edb3708c8c5 6360 break;
whismanoid 0:3edb3708c8c5 6361 case '~': // TODO: IGNORE_AT_COMMANDS -- ignore ~~~ modem command
whismanoid 0:3edb3708c8c5 6362 {
whismanoid 0:3edb3708c8c5 6363 // TODO: '~' is not recommended for menu commands, interferes with ssh
whismanoid 0:3edb3708c8c5 6364 #if IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6365 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6366 cmdLine_DAPLINKserial.serial().printf("\r\n ignore AT command \"%s\"\r\n", cmdLine.str());
whismanoid 0:3edb3708c8c5 6367 # endif // HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6368 #endif // IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6369 }
whismanoid 0:3edb3708c8c5 6370 break;
whismanoid 0:3edb3708c8c5 6371 case '+': // TODO: IGNORE_AT_COMMANDS -- ignore +++ modem command
whismanoid 0:3edb3708c8c5 6372 {
whismanoid 0:3edb3708c8c5 6373 #if IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6374 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6375 cmdLine_DAPLINKserial.serial().printf("\r\n ignore AT command \"%s\"\r\n", cmdLine.str());
whismanoid 0:3edb3708c8c5 6376 # endif // HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6377 #endif // IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6378 }
whismanoid 0:3edb3708c8c5 6379 break;
whismanoid 0:3edb3708c8c5 6380 #endif // APPLICATION_MAX11131
whismanoid 0:3edb3708c8c5 6381
whismanoid 0:3edb3708c8c5 6382 #if APPLICATION_MAX5171 // main_menu_onEOLcommandParser
whismanoid 0:3edb3708c8c5 6383 // MAX5171 main_menu_onEOLcommandParser
whismanoid 0:3edb3708c8c5 6384 case '0':
whismanoid 0:3edb3708c8c5 6385 {
whismanoid 0:3edb3708c8c5 6386 // recommended for hex command codes 10..1F
whismanoid 0:3edb3708c8c5 6387 //~ cmdLine.serial().printf("\r\n 0 code=? -- CODE");
whismanoid 0:3edb3708c8c5 6388 uint16_t code;
whismanoid 0:3edb3708c8c5 6389 if (cmdLine.parse_uint16_dec("code", code))
whismanoid 0:3edb3708c8c5 6390 {
whismanoid 0:3edb3708c8c5 6391 }
whismanoid 0:3edb3708c8c5 6392 cmdLine.serial().printf("CODE code=%d", code);
whismanoid 0:3edb3708c8c5 6393 g_MAX5171_device.CODE(code);
whismanoid 0:3edb3708c8c5 6394 }
whismanoid 0:3edb3708c8c5 6395 break;
whismanoid 0:3edb3708c8c5 6396 case '4':
whismanoid 0:3edb3708c8c5 6397 {
whismanoid 0:3edb3708c8c5 6398 // recommended for hex command codes 10..1F
whismanoid 0:3edb3708c8c5 6399 //~ cmdLine.serial().printf("\r\n 4 code=? -- CODE_LOAD");
whismanoid 0:3edb3708c8c5 6400 uint16_t code;
whismanoid 0:3edb3708c8c5 6401 if (cmdLine.parse_uint16_dec("code", code))
whismanoid 0:3edb3708c8c5 6402 {
whismanoid 0:3edb3708c8c5 6403 }
whismanoid 0:3edb3708c8c5 6404 cmdLine.serial().printf("CODE_LOAD code=%d", code);
whismanoid 0:3edb3708c8c5 6405 g_MAX5171_device.CODE_LOAD(code);
whismanoid 0:3edb3708c8c5 6406 }
whismanoid 0:3edb3708c8c5 6407 break;
whismanoid 0:3edb3708c8c5 6408 case '8':
whismanoid 0:3edb3708c8c5 6409 {
whismanoid 0:3edb3708c8c5 6410 // recommended for hex command codes 10..1F
whismanoid 0:3edb3708c8c5 6411 //~ cmdLine.serial().printf("\r\n 8 -- LOAD");
whismanoid 0:3edb3708c8c5 6412 cmdLine.serial().printf("LOAD");
whismanoid 0:3edb3708c8c5 6413 g_MAX5171_device.LOAD();
whismanoid 0:3edb3708c8c5 6414 }
whismanoid 0:3edb3708c8c5 6415 break;
whismanoid 0:3edb3708c8c5 6416 case 'c': case 'C':
whismanoid 0:3edb3708c8c5 6417 {
whismanoid 0:3edb3708c8c5 6418 // recommended for hex command codes 10..1F
whismanoid 0:3edb3708c8c5 6419 //~ cmdLine.serial().printf("\r\n c -- NOP");
whismanoid 0:3edb3708c8c5 6420 cmdLine.serial().printf("NOP");
whismanoid 0:3edb3708c8c5 6421 g_MAX5171_device.NOP();
whismanoid 0:3edb3708c8c5 6422 }
whismanoid 0:3edb3708c8c5 6423 break;
whismanoid 0:3edb3708c8c5 6424 case 'd': case 'D':
whismanoid 0:3edb3708c8c5 6425 {
whismanoid 0:3edb3708c8c5 6426 // recommended for hex command codes 10..1F
whismanoid 0:3edb3708c8c5 6427 //~ cmdLine.serial().printf("\r\n d -- SHUTDOWN");
whismanoid 0:3edb3708c8c5 6428 cmdLine.serial().printf("SHUTDOWN");
whismanoid 0:3edb3708c8c5 6429 g_MAX5171_device.SHUTDOWN();
whismanoid 0:3edb3708c8c5 6430 }
whismanoid 0:3edb3708c8c5 6431 break;
whismanoid 0:3edb3708c8c5 6432 case 'e': case 'E':
whismanoid 0:3edb3708c8c5 6433 {
whismanoid 0:3edb3708c8c5 6434 switch (cmdLine[1])
whismanoid 0:3edb3708c8c5 6435 {
whismanoid 0:3edb3708c8c5 6436 case '0':
whismanoid 0:3edb3708c8c5 6437 {
whismanoid 0:3edb3708c8c5 6438 // recommended for hex command codes 10..1F
whismanoid 0:3edb3708c8c5 6439 //~ cmdLine.serial().printf("\r\n e0 -- UPO_LOW");
whismanoid 0:3edb3708c8c5 6440 cmdLine.serial().printf("UPO_LOW");
whismanoid 0:3edb3708c8c5 6441 g_MAX5171_device.UPO_LOW();
whismanoid 0:3edb3708c8c5 6442 }
whismanoid 0:3edb3708c8c5 6443 break;
whismanoid 0:3edb3708c8c5 6444 case '8':
whismanoid 0:3edb3708c8c5 6445 {
whismanoid 0:3edb3708c8c5 6446 // recommended for hex command codes 10..1F
whismanoid 0:3edb3708c8c5 6447 //~ cmdLine.serial().printf("\r\n e8 -- UPO_HIGH");
whismanoid 0:3edb3708c8c5 6448 cmdLine.serial().printf("UPO_HIGH");
whismanoid 0:3edb3708c8c5 6449 g_MAX5171_device.UPO_HIGH();
whismanoid 0:3edb3708c8c5 6450 }
whismanoid 0:3edb3708c8c5 6451 break;
whismanoid 0:3edb3708c8c5 6452 }
whismanoid 0:3edb3708c8c5 6453 }
whismanoid 0:3edb3708c8c5 6454 break;
whismanoid 0:3edb3708c8c5 6455 case 'f': case 'F':
whismanoid 0:3edb3708c8c5 6456 {
whismanoid 0:3edb3708c8c5 6457 switch (cmdLine[1])
whismanoid 0:3edb3708c8c5 6458 {
whismanoid 0:3edb3708c8c5 6459 case '0':
whismanoid 0:3edb3708c8c5 6460 {
whismanoid 0:3edb3708c8c5 6461 // recommended for hex command codes 10..1F
whismanoid 0:3edb3708c8c5 6462 //~ cmdLine.serial().printf("\r\n f0 -- MODE1_DOUT_SCLK_RISING_EDGE");
whismanoid 0:3edb3708c8c5 6463 cmdLine.serial().printf("MODE1_DOUT_SCLK_RISING_EDGE");
whismanoid 0:3edb3708c8c5 6464 g_MAX5171_device.MODE1_DOUT_SCLK_RISING_EDGE();
whismanoid 0:3edb3708c8c5 6465 }
whismanoid 0:3edb3708c8c5 6466 break;
whismanoid 0:3edb3708c8c5 6467 case '8':
whismanoid 0:3edb3708c8c5 6468 {
whismanoid 0:3edb3708c8c5 6469 // recommended for hex command codes 10..1F
whismanoid 0:3edb3708c8c5 6470 //~ cmdLine.serial().printf("\r\n f8 -- MODE0_DOUT_SCLK_FALLING_EDGE");
whismanoid 0:3edb3708c8c5 6471 cmdLine.serial().printf("MODE0_DOUT_SCLK_FALLING_EDGE");
whismanoid 0:3edb3708c8c5 6472 g_MAX5171_device.MODE0_DOUT_SCLK_FALLING_EDGE();
whismanoid 0:3edb3708c8c5 6473 }
whismanoid 0:3edb3708c8c5 6474 break;
whismanoid 0:3edb3708c8c5 6475 }
whismanoid 0:3edb3708c8c5 6476 }
whismanoid 0:3edb3708c8c5 6477 break;
whismanoid 0:3edb3708c8c5 6478 case 'a': case 'A':
whismanoid 0:3edb3708c8c5 6479 {
whismanoid 0:3edb3708c8c5 6480 // recommended for hex command codes A0..AF
whismanoid 0:3edb3708c8c5 6481 switch (cmdLine[1])
whismanoid 0:3edb3708c8c5 6482 {
whismanoid 0:3edb3708c8c5 6483 case 't': case 'T':
whismanoid 0:3edb3708c8c5 6484 #if IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6485 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6486 cmdLine_DAPLINKserial.serial().printf("\r\n ignore AT command \"%s\"\r\n", cmdLine.str());
whismanoid 0:3edb3708c8c5 6487 # endif // HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6488 // AT command: skip the prompt to avoid confusing modem detector
whismanoid 0:3edb3708c8c5 6489 return;
whismanoid 0:3edb3708c8c5 6490 #endif // IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6491 }
whismanoid 0:3edb3708c8c5 6492 }
whismanoid 0:3edb3708c8c5 6493 break;
whismanoid 0:3edb3708c8c5 6494 case 'x': case 'X':
whismanoid 0:3edb3708c8c5 6495 {
whismanoid 0:3edb3708c8c5 6496 }
whismanoid 0:3edb3708c8c5 6497 break;
whismanoid 0:3edb3708c8c5 6498 case 'y': case 'Y':
whismanoid 0:3edb3708c8c5 6499 {
whismanoid 0:3edb3708c8c5 6500 }
whismanoid 0:3edb3708c8c5 6501 break;
whismanoid 0:3edb3708c8c5 6502 case 'z': case 'Z':
whismanoid 0:3edb3708c8c5 6503 {
whismanoid 0:3edb3708c8c5 6504 }
whismanoid 0:3edb3708c8c5 6505 break;
whismanoid 0:3edb3708c8c5 6506 case '~': // TODO: IGNORE_AT_COMMANDS -- ignore ~~~ modem command
whismanoid 0:3edb3708c8c5 6507 {
whismanoid 0:3edb3708c8c5 6508 // TODO: '~' is not recommended for menu commands, interferes with ssh
whismanoid 0:3edb3708c8c5 6509 #if IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6510 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6511 cmdLine_DAPLINKserial.serial().printf("\r\n ignore AT command \"%s\"\r\n", cmdLine.str());
whismanoid 0:3edb3708c8c5 6512 # endif // HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6513 #endif // IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6514 }
whismanoid 0:3edb3708c8c5 6515 break;
whismanoid 0:3edb3708c8c5 6516 case '+': // TODO: IGNORE_AT_COMMANDS -- ignore +++ modem command
whismanoid 0:3edb3708c8c5 6517 {
whismanoid 0:3edb3708c8c5 6518 #if IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6519 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6520 cmdLine_DAPLINKserial.serial().printf("\r\n ignore AT command \"%s\"\r\n", cmdLine.str());
whismanoid 0:3edb3708c8c5 6521 # endif // HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6522 #endif // IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6523 }
whismanoid 0:3edb3708c8c5 6524 break;
whismanoid 0:3edb3708c8c5 6525 #endif // APPLICATION_MAX5171
whismanoid 0:3edb3708c8c5 6526
whismanoid 0:3edb3708c8c5 6527
whismanoid 0:3edb3708c8c5 6528 #if APPLICATION_MAX11410 // main_menu_onEOLcommandParser
whismanoid 0:3edb3708c8c5 6529 // TODO1: MAX11410 main_menu_onEOLcommandParser
whismanoid 0:3edb3708c8c5 6530 case '0':
whismanoid 0:3edb3708c8c5 6531 {
whismanoid 0:3edb3708c8c5 6532 // recommended for hex command codes 00..0F
whismanoid 0:3edb3708c8c5 6533 // placeholder: cmdLine.serial().printf("\r\n 3 ch=? code=? -- CODEnLOADn");
whismanoid 0:3edb3708c8c5 6534 uint16_t ch = g_MAX5715_device.channelNumber_0_3;
whismanoid 0:3edb3708c8c5 6535 uint16_t code;
whismanoid 0:3edb3708c8c5 6536 if (cmdLine.parse_uint16_dec("ch", ch))
whismanoid 0:3edb3708c8c5 6537 {
whismanoid 0:3edb3708c8c5 6538 }
whismanoid 0:3edb3708c8c5 6539 if (cmdLine.parse_uint16_dec("code", code))
whismanoid 0:3edb3708c8c5 6540 {
whismanoid 0:3edb3708c8c5 6541 }
whismanoid 0:3edb3708c8c5 6542 if (cmdLine.parse_flag("xyzzy", g_xyzzy_flag, XYZZY_FLAG))
whismanoid 0:3edb3708c8c5 6543 {
whismanoid 0:3edb3708c8c5 6544 isUpdatedSPIConfig = true;
whismanoid 0:3edb3708c8c5 6545 }
whismanoid 0:3edb3708c8c5 6546 cmdLine.serial().printf("CODEnLOADn ch=%d code=%d", ch, code);
whismanoid 0:3edb3708c8c5 6547 MAX5715_CODEnLOADn(ch, code);
whismanoid 0:3edb3708c8c5 6548 cmdLine.serial().printf("\r\n placeholder");
whismanoid 0:3edb3708c8c5 6549 }
whismanoid 0:3edb3708c8c5 6550 break;
whismanoid 0:3edb3708c8c5 6551 case '1':
whismanoid 0:3edb3708c8c5 6552 {
whismanoid 0:3edb3708c8c5 6553 // recommended for hex command codes 10..1F
whismanoid 0:3edb3708c8c5 6554 }
whismanoid 0:3edb3708c8c5 6555 break;
whismanoid 0:3edb3708c8c5 6556 case '2':
whismanoid 0:3edb3708c8c5 6557 {
whismanoid 0:3edb3708c8c5 6558 // recommended for hex command codes 20..2F
whismanoid 0:3edb3708c8c5 6559 }
whismanoid 0:3edb3708c8c5 6560 break;
whismanoid 0:3edb3708c8c5 6561 case '3':
whismanoid 0:3edb3708c8c5 6562 {
whismanoid 0:3edb3708c8c5 6563 // recommended for hex command codes 30..3F
whismanoid 0:3edb3708c8c5 6564 }
whismanoid 0:3edb3708c8c5 6565 break;
whismanoid 0:3edb3708c8c5 6566 case '4':
whismanoid 0:3edb3708c8c5 6567 {
whismanoid 0:3edb3708c8c5 6568 // recommended for hex command codes 40..4F
whismanoid 0:3edb3708c8c5 6569 }
whismanoid 0:3edb3708c8c5 6570 break;
whismanoid 0:3edb3708c8c5 6571 case '5':
whismanoid 0:3edb3708c8c5 6572 {
whismanoid 0:3edb3708c8c5 6573 // recommended for hex command codes 50..5F
whismanoid 0:3edb3708c8c5 6574 }
whismanoid 0:3edb3708c8c5 6575 break;
whismanoid 0:3edb3708c8c5 6576 case '6':
whismanoid 0:3edb3708c8c5 6577 {
whismanoid 0:3edb3708c8c5 6578 // recommended for hex command codes 60..6F
whismanoid 0:3edb3708c8c5 6579 }
whismanoid 0:3edb3708c8c5 6580 break;
whismanoid 0:3edb3708c8c5 6581 case '7':
whismanoid 0:3edb3708c8c5 6582 {
whismanoid 0:3edb3708c8c5 6583 // recommended for hex command codes 70..7F
whismanoid 0:3edb3708c8c5 6584 }
whismanoid 0:3edb3708c8c5 6585 break;
whismanoid 0:3edb3708c8c5 6586 case '8':
whismanoid 0:3edb3708c8c5 6587 {
whismanoid 0:3edb3708c8c5 6588 // recommended for hex command codes 80..8F
whismanoid 0:3edb3708c8c5 6589 }
whismanoid 0:3edb3708c8c5 6590 break;
whismanoid 0:3edb3708c8c5 6591 case '9':
whismanoid 0:3edb3708c8c5 6592 {
whismanoid 0:3edb3708c8c5 6593 // recommended for hex command codes 90..9F
whismanoid 0:3edb3708c8c5 6594 }
whismanoid 0:3edb3708c8c5 6595 break;
whismanoid 0:3edb3708c8c5 6596 case 'a': case 'A':
whismanoid 0:3edb3708c8c5 6597 {
whismanoid 0:3edb3708c8c5 6598 // recommended for hex command codes A0..AF
whismanoid 0:3edb3708c8c5 6599 switch (cmdLine[1])
whismanoid 0:3edb3708c8c5 6600 {
whismanoid 0:3edb3708c8c5 6601 case 't': case 'T':
whismanoid 0:3edb3708c8c5 6602 #if IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6603 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6604 cmdLine_DAPLINKserial.serial().printf("\r\n ignore AT command \"%s\"\r\n", cmdLine.str());
whismanoid 0:3edb3708c8c5 6605 # endif // HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6606 // AT command: skip the prompt to avoid confusing modem detector
whismanoid 0:3edb3708c8c5 6607 return;
whismanoid 0:3edb3708c8c5 6608 #endif // IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6609 }
whismanoid 0:3edb3708c8c5 6610 }
whismanoid 0:3edb3708c8c5 6611 break;
whismanoid 0:3edb3708c8c5 6612 case 'b': case 'B':
whismanoid 0:3edb3708c8c5 6613 {
whismanoid 0:3edb3708c8c5 6614 // recommended for hex command codes B0..BF
whismanoid 0:3edb3708c8c5 6615 }
whismanoid 0:3edb3708c8c5 6616 break;
whismanoid 0:3edb3708c8c5 6617 case 'c': case 'C':
whismanoid 0:3edb3708c8c5 6618 {
whismanoid 0:3edb3708c8c5 6619 // recommended for hex command codes C0..CF
whismanoid 0:3edb3708c8c5 6620 }
whismanoid 0:3edb3708c8c5 6621 break;
whismanoid 0:3edb3708c8c5 6622 case 'd': case 'D':
whismanoid 0:3edb3708c8c5 6623 {
whismanoid 0:3edb3708c8c5 6624 // recommended for hex command codes D0..DF
whismanoid 0:3edb3708c8c5 6625 }
whismanoid 0:3edb3708c8c5 6626 break;
whismanoid 0:3edb3708c8c5 6627 case 'e': case 'E':
whismanoid 0:3edb3708c8c5 6628 {
whismanoid 0:3edb3708c8c5 6629 // recommended for hex command codes E0..EF
whismanoid 0:3edb3708c8c5 6630 }
whismanoid 0:3edb3708c8c5 6631 break;
whismanoid 0:3edb3708c8c5 6632 case 'f': case 'F':
whismanoid 0:3edb3708c8c5 6633 {
whismanoid 0:3edb3708c8c5 6634 // recommended for hex command codes F0..FF
whismanoid 0:3edb3708c8c5 6635 }
whismanoid 0:3edb3708c8c5 6636 break;
whismanoid 0:3edb3708c8c5 6637 case 'x': case 'X':
whismanoid 0:3edb3708c8c5 6638 {
whismanoid 0:3edb3708c8c5 6639 }
whismanoid 0:3edb3708c8c5 6640 break;
whismanoid 0:3edb3708c8c5 6641 case 'y': case 'Y':
whismanoid 0:3edb3708c8c5 6642 {
whismanoid 0:3edb3708c8c5 6643 }
whismanoid 0:3edb3708c8c5 6644 break;
whismanoid 0:3edb3708c8c5 6645 case 'z': case 'Z':
whismanoid 0:3edb3708c8c5 6646 {
whismanoid 0:3edb3708c8c5 6647 }
whismanoid 0:3edb3708c8c5 6648 break;
whismanoid 0:3edb3708c8c5 6649 case '~': // TODO: IGNORE_AT_COMMANDS -- ignore ~~~ modem command
whismanoid 0:3edb3708c8c5 6650 {
whismanoid 0:3edb3708c8c5 6651 // TODO: '~' is not recommended for menu commands, interferes with ssh
whismanoid 0:3edb3708c8c5 6652 #if IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6653 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6654 cmdLine_DAPLINKserial.serial().printf("\r\n ignore AT command \"%s\"\r\n", cmdLine.str());
whismanoid 0:3edb3708c8c5 6655 # endif // HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6656 #endif // IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6657 }
whismanoid 0:3edb3708c8c5 6658 break;
whismanoid 0:3edb3708c8c5 6659 case '+': // TODO: IGNORE_AT_COMMANDS -- ignore +++ modem command
whismanoid 0:3edb3708c8c5 6660 {
whismanoid 0:3edb3708c8c5 6661 #if IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6662 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6663 cmdLine_DAPLINKserial.serial().printf("\r\n ignore AT command \"%s\"\r\n", cmdLine.str());
whismanoid 0:3edb3708c8c5 6664 # endif // HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6665 #endif // IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6666 }
whismanoid 0:3edb3708c8c5 6667 break;
whismanoid 0:3edb3708c8c5 6668 #endif // APPLICATION_MAX11410
whismanoid 0:3edb3708c8c5 6669
whismanoid 0:3edb3708c8c5 6670
whismanoid 0:3edb3708c8c5 6671 #if APPLICATION_MAX12345 // main_menu_onEOLcommandParser
whismanoid 0:3edb3708c8c5 6672 case '0':
whismanoid 0:3edb3708c8c5 6673 {
whismanoid 0:3edb3708c8c5 6674 // recommended for hex command codes 00..0F
whismanoid 0:3edb3708c8c5 6675 // placeholder: cmdLine.serial().printf("\r\n 3 ch=? code=? -- CODEnLOADn");
whismanoid 0:3edb3708c8c5 6676 uint16_t ch = g_MAX5715_device.channelNumber_0_3;
whismanoid 0:3edb3708c8c5 6677 uint16_t code;
whismanoid 0:3edb3708c8c5 6678 if (cmdLine.parse_uint16_dec("ch", ch))
whismanoid 0:3edb3708c8c5 6679 {
whismanoid 0:3edb3708c8c5 6680 }
whismanoid 0:3edb3708c8c5 6681 if (cmdLine.parse_uint16_dec("code", code))
whismanoid 0:3edb3708c8c5 6682 {
whismanoid 0:3edb3708c8c5 6683 }
whismanoid 0:3edb3708c8c5 6684 if (cmdLine.parse_flag("xyzzy", g_xyzzy_flag, XYZZY_FLAG))
whismanoid 0:3edb3708c8c5 6685 {
whismanoid 0:3edb3708c8c5 6686 isUpdatedSPIConfig = true;
whismanoid 0:3edb3708c8c5 6687 }
whismanoid 0:3edb3708c8c5 6688 cmdLine.serial().printf("CODEnLOADn ch=%d code=%d", ch, code);
whismanoid 0:3edb3708c8c5 6689 MAX5715_CODEnLOADn(ch, code);
whismanoid 0:3edb3708c8c5 6690 cmdLine.serial().printf("\r\n placeholder");
whismanoid 0:3edb3708c8c5 6691 }
whismanoid 0:3edb3708c8c5 6692 break;
whismanoid 0:3edb3708c8c5 6693 case '1':
whismanoid 0:3edb3708c8c5 6694 {
whismanoid 0:3edb3708c8c5 6695 // recommended for hex command codes 10..1F
whismanoid 0:3edb3708c8c5 6696 }
whismanoid 0:3edb3708c8c5 6697 break;
whismanoid 0:3edb3708c8c5 6698 case '2':
whismanoid 0:3edb3708c8c5 6699 {
whismanoid 0:3edb3708c8c5 6700 // recommended for hex command codes 20..2F
whismanoid 0:3edb3708c8c5 6701 }
whismanoid 0:3edb3708c8c5 6702 break;
whismanoid 0:3edb3708c8c5 6703 case '3':
whismanoid 0:3edb3708c8c5 6704 {
whismanoid 0:3edb3708c8c5 6705 // recommended for hex command codes 30..3F
whismanoid 0:3edb3708c8c5 6706 }
whismanoid 0:3edb3708c8c5 6707 break;
whismanoid 0:3edb3708c8c5 6708 case '4':
whismanoid 0:3edb3708c8c5 6709 {
whismanoid 0:3edb3708c8c5 6710 // recommended for hex command codes 40..4F
whismanoid 0:3edb3708c8c5 6711 }
whismanoid 0:3edb3708c8c5 6712 break;
whismanoid 0:3edb3708c8c5 6713 case '5':
whismanoid 0:3edb3708c8c5 6714 {
whismanoid 0:3edb3708c8c5 6715 // recommended for hex command codes 50..5F
whismanoid 0:3edb3708c8c5 6716 }
whismanoid 0:3edb3708c8c5 6717 break;
whismanoid 0:3edb3708c8c5 6718 case '6':
whismanoid 0:3edb3708c8c5 6719 {
whismanoid 0:3edb3708c8c5 6720 // recommended for hex command codes 60..6F
whismanoid 0:3edb3708c8c5 6721 }
whismanoid 0:3edb3708c8c5 6722 break;
whismanoid 0:3edb3708c8c5 6723 case '7':
whismanoid 0:3edb3708c8c5 6724 {
whismanoid 0:3edb3708c8c5 6725 // recommended for hex command codes 70..7F
whismanoid 0:3edb3708c8c5 6726 }
whismanoid 0:3edb3708c8c5 6727 break;
whismanoid 0:3edb3708c8c5 6728 case '8':
whismanoid 0:3edb3708c8c5 6729 {
whismanoid 0:3edb3708c8c5 6730 // recommended for hex command codes 80..8F
whismanoid 0:3edb3708c8c5 6731 }
whismanoid 0:3edb3708c8c5 6732 break;
whismanoid 0:3edb3708c8c5 6733 case '9':
whismanoid 0:3edb3708c8c5 6734 {
whismanoid 0:3edb3708c8c5 6735 // recommended for hex command codes 90..9F
whismanoid 0:3edb3708c8c5 6736 }
whismanoid 0:3edb3708c8c5 6737 break;
whismanoid 0:3edb3708c8c5 6738 case 'a': case 'A':
whismanoid 0:3edb3708c8c5 6739 {
whismanoid 0:3edb3708c8c5 6740 // recommended for hex command codes A0..AF
whismanoid 0:3edb3708c8c5 6741 switch (cmdLine[1])
whismanoid 0:3edb3708c8c5 6742 {
whismanoid 0:3edb3708c8c5 6743 case 't': case 'T':
whismanoid 0:3edb3708c8c5 6744 #if IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6745 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6746 cmdLine_DAPLINKserial.serial().printf("\r\n ignore AT command \"%s\"\r\n", cmdLine.str());
whismanoid 0:3edb3708c8c5 6747 # endif // HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6748 // AT command: skip the prompt to avoid confusing modem detector
whismanoid 0:3edb3708c8c5 6749 return;
whismanoid 0:3edb3708c8c5 6750 #endif // IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6751 }
whismanoid 0:3edb3708c8c5 6752 }
whismanoid 0:3edb3708c8c5 6753 break;
whismanoid 0:3edb3708c8c5 6754 case 'b': case 'B':
whismanoid 0:3edb3708c8c5 6755 {
whismanoid 0:3edb3708c8c5 6756 // recommended for hex command codes B0..BF
whismanoid 0:3edb3708c8c5 6757 }
whismanoid 0:3edb3708c8c5 6758 break;
whismanoid 0:3edb3708c8c5 6759 case 'c': case 'C':
whismanoid 0:3edb3708c8c5 6760 {
whismanoid 0:3edb3708c8c5 6761 // recommended for hex command codes C0..CF
whismanoid 0:3edb3708c8c5 6762 }
whismanoid 0:3edb3708c8c5 6763 break;
whismanoid 0:3edb3708c8c5 6764 case 'd': case 'D':
whismanoid 0:3edb3708c8c5 6765 {
whismanoid 0:3edb3708c8c5 6766 // recommended for hex command codes D0..DF
whismanoid 0:3edb3708c8c5 6767 }
whismanoid 0:3edb3708c8c5 6768 break;
whismanoid 0:3edb3708c8c5 6769 case 'e': case 'E':
whismanoid 0:3edb3708c8c5 6770 {
whismanoid 0:3edb3708c8c5 6771 // recommended for hex command codes E0..EF
whismanoid 0:3edb3708c8c5 6772 }
whismanoid 0:3edb3708c8c5 6773 break;
whismanoid 0:3edb3708c8c5 6774 case 'f': case 'F':
whismanoid 0:3edb3708c8c5 6775 {
whismanoid 0:3edb3708c8c5 6776 // recommended for hex command codes F0..FF
whismanoid 0:3edb3708c8c5 6777 }
whismanoid 0:3edb3708c8c5 6778 break;
whismanoid 0:3edb3708c8c5 6779 case 'x': case 'X':
whismanoid 0:3edb3708c8c5 6780 {
whismanoid 0:3edb3708c8c5 6781 }
whismanoid 0:3edb3708c8c5 6782 break;
whismanoid 0:3edb3708c8c5 6783 case 'y': case 'Y':
whismanoid 0:3edb3708c8c5 6784 {
whismanoid 0:3edb3708c8c5 6785 }
whismanoid 0:3edb3708c8c5 6786 break;
whismanoid 0:3edb3708c8c5 6787 case 'z': case 'Z':
whismanoid 0:3edb3708c8c5 6788 {
whismanoid 0:3edb3708c8c5 6789 }
whismanoid 0:3edb3708c8c5 6790 break;
whismanoid 0:3edb3708c8c5 6791 case '~': // TODO: IGNORE_AT_COMMANDS -- ignore ~~~ modem command
whismanoid 0:3edb3708c8c5 6792 {
whismanoid 0:3edb3708c8c5 6793 // TODO: '~' is not recommended for menu commands, interferes with ssh
whismanoid 0:3edb3708c8c5 6794 #if IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6795 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6796 cmdLine_DAPLINKserial.serial().printf("\r\n ignore AT command \"%s\"\r\n", cmdLine.str());
whismanoid 0:3edb3708c8c5 6797 # endif // HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6798 #endif // IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6799 }
whismanoid 0:3edb3708c8c5 6800 break;
whismanoid 0:3edb3708c8c5 6801 case '+': // TODO: IGNORE_AT_COMMANDS -- ignore +++ modem command
whismanoid 0:3edb3708c8c5 6802 {
whismanoid 0:3edb3708c8c5 6803 #if IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6804 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6805 cmdLine_DAPLINKserial.serial().printf("\r\n ignore AT command \"%s\"\r\n", cmdLine.str());
whismanoid 0:3edb3708c8c5 6806 # endif // HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6807 #endif // IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6808 }
whismanoid 0:3edb3708c8c5 6809 break;
whismanoid 0:3edb3708c8c5 6810 #endif // APPLICATION_MAX12345
whismanoid 0:3edb3708c8c5 6811
whismanoid 0:3edb3708c8c5 6812 //#if IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6813 // // tolerate AT commands, which may be sent during probe
whismanoid 0:3edb3708c8c5 6814 // // "AT\r"
whismanoid 0:3edb3708c8c5 6815 // // "AT+CGMI\r" -- request manufacturer identification AT+CMGI=?
whismanoid 0:3edb3708c8c5 6816 // // "AT+CGMM\r" -- request manufacturer model
whismanoid 0:3edb3708c8c5 6817 // // "AT%IPSYS?\r"
whismanoid 0:3edb3708c8c5 6818 // // "ATE0\r" -- echo disable
whismanoid 0:3edb3708c8c5 6819 // // "ATV1\r" -- verbose result codes OK | ERROR | NO CARRIER
whismanoid 0:3edb3708c8c5 6820 // // menu_main() ignore_until_line_end: AT
whismanoid 0:3edb3708c8c5 6821 // // menu_main() ignore_until_line_end: AT+CGMI
whismanoid 0:3edb3708c8c5 6822 // // menu_main() ignore_until_line_end: AT+CGMM
whismanoid 0:3edb3708c8c5 6823 // // menu_main() ignore_until_line_end: AT%IPSYS?
whismanoid 0:3edb3708c8c5 6824 // // menu_main() ignore_until_line_end: ATE0
whismanoid 0:3edb3708c8c5 6825 // // menu_main() ignore_until_line_end: ATV1
whismanoid 0:3edb3708c8c5 6826 // // menu_main() ignore_until_line_end: AT+CMEE=1
whismanoid 0:3edb3708c8c5 6827 // // menu_main() ignore_until_line_end: ATX4
whismanoid 0:3edb3708c8c5 6828 // // menu_main() ignore_until_line_end: AT&C1
whismanoid 0:3edb3708c8c5 6829 // // menu_main() ignore_until_line_end: ATE0
whismanoid 0:3edb3708c8c5 6830 // // menu_main() ignore_until_line_end: AT+CMEE=1
whismanoid 0:3edb3708c8c5 6831 // // menu_main() ignore_until_line_end: AT+GCAP
whismanoid 0:3edb3708c8c5 6832 // // menu_main() ignore_until_line_end: ATI
whismanoid 0:3edb3708c8c5 6833 // // menu_main() ignore_until_line_end: AT+CPIN?
whismanoid 0:3edb3708c8c5 6834 // // menu_main() ignore_until_line_end: AT+CGMM
whismanoid 0:3edb3708c8c5 6835 // case 'A':
whismanoid 0:3edb3708c8c5 6836 // // likely unwanted AT command, host probing for a modem.
whismanoid 0:3edb3708c8c5 6837 // // ignore everything up to next line end '\r' or '\n'.
whismanoid 0:3edb3708c8c5 6838 // //~ ignore_until_line_end = true;
whismanoid 0:3edb3708c8c5 6839 //# if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6840 // cmdLine_DAPLINKserial.serial().printf("\r\n ignore AT command \"%s\"\r\n", cmdLine.str());
whismanoid 0:3edb3708c8c5 6841 //# endif // HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6842 // //~ goto label_menu_main_idle;
whismanoid 0:3edb3708c8c5 6843 // break;
whismanoid 0:3edb3708c8c5 6844 //#endif // IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 6845 //
whismanoid 0:3edb3708c8c5 6846 //
whismanoid 0:3edb3708c8c5 6847 // TODO1: add new commands here
whismanoid 0:3edb3708c8c5 6848 //
whismanoid 0:3edb3708c8c5 6849 default:
whismanoid 0:3edb3708c8c5 6850 cmdLine.serial().printf("\r\n unknown command 0x%2.2x \"%s\"\r\n", cmdLine.str()[0], cmdLine.str());
whismanoid 0:3edb3708c8c5 6851 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6852 cmdLine_DAPLINKserial.serial().printf("\r\n unknown command 0x%2.2x \"%s\"\r\n",
whismanoid 0:3edb3708c8c5 6853 cmdLine.str()[0], cmdLine.str());
whismanoid 0:3edb3708c8c5 6854 # endif // HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6855 } // switch (cmdLine[0])
whismanoid 0:3edb3708c8c5 6856 //
whismanoid 0:3edb3708c8c5 6857 // print command prompt
whismanoid 0:3edb3708c8c5 6858 #if APPLICATION_MAX5715 // main_menu_onEOLcommandParser print command prompt
whismanoid 0:3edb3708c8c5 6859 cmdLine.serial().printf("\r\nMAX5715 > ");
whismanoid 0:3edb3708c8c5 6860 #elif APPLICATION_MAX11131 // main_menu_onEOLcommandParser print command prompt
whismanoid 0:3edb3708c8c5 6861 cmdLine.serial().printf("\r\nMAX11131 > ");
whismanoid 0:3edb3708c8c5 6862 #elif APPLICATION_MAX5171 // main_menu_onEOLcommandParser print command prompt
whismanoid 0:3edb3708c8c5 6863 cmdLine.serial().printf("\r\nMAX5171 > ");
whismanoid 0:3edb3708c8c5 6864 #elif APPLICATION_MAX11410 // main_menu_onEOLcommandParser print command prompt
whismanoid 0:3edb3708c8c5 6865 cmdLine.serial().printf("\r\nMAX11410 > ");
whismanoid 0:3edb3708c8c5 6866 #elif APPLICATION_MAX12345 // main_menu_onEOLcommandParser print command prompt
whismanoid 0:3edb3708c8c5 6867 cmdLine.serial().printf("\r\nMAX12345 > ");
whismanoid 0:3edb3708c8c5 6868 #else
whismanoid 0:3edb3708c8c5 6869 cmdLine.serial().printf("\r\n> ");
whismanoid 0:3edb3708c8c5 6870 #endif
whismanoid 0:3edb3708c8c5 6871 }
whismanoid 0:3edb3708c8c5 6872 #endif //USE_COMMAND_BUFFER
whismanoid 0:3edb3708c8c5 6873
whismanoid 0:3edb3708c8c5 6874 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 6875 void InitializeConfiguration()
whismanoid 0:3edb3708c8c5 6876 {
whismanoid 0:3edb3708c8c5 6877
whismanoid 0:3edb3708c8c5 6878 #if APPLICATION_MAX5715 // InitializeConfiguration
whismanoid 0:3edb3708c8c5 6879 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6880 cmdLine_DAPLINKserial.serial().printf("\r\nMAX5715_Init()");
whismanoid 0:3edb3708c8c5 6881 # endif
whismanoid 0:3edb3708c8c5 6882 # if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 6883 cmdLine_microUSBserial.serial().printf("\r\nMAX5715_Init()");
whismanoid 0:3edb3708c8c5 6884 # endif
whismanoid 0:3edb3708c8c5 6885 int initResult = g_MAX5715_device.Init(); // defined in #include MAX5715.h
whismanoid 0:3edb3708c8c5 6886 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6887 cmdLine_DAPLINKserial.serial().printf("\r\nMAX5715_Init() returned %d\r\n", initResult);
whismanoid 0:3edb3708c8c5 6888 # endif
whismanoid 0:3edb3708c8c5 6889 # if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 6890 cmdLine_microUSBserial.serial().printf("\r\nMAX5715_Init() returned %d\r\n", initResult);
whismanoid 0:3edb3708c8c5 6891 # endif
whismanoid 0:3edb3708c8c5 6892 #endif // APPLICATION_MAX5715
whismanoid 0:3edb3708c8c5 6893
whismanoid 0:3edb3708c8c5 6894 #if APPLICATION_MAX11131 // InitializeConfiguration
whismanoid 0:3edb3708c8c5 6895 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6896 cmdLine_DAPLINKserial.serial().printf("\r\nMAX11131_Init()");
whismanoid 0:3edb3708c8c5 6897 # endif
whismanoid 0:3edb3708c8c5 6898 # if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 6899 cmdLine_microUSBserial.serial().printf("\r\nMAX11131_Init()");
whismanoid 0:3edb3708c8c5 6900 # endif
whismanoid 0:3edb3708c8c5 6901 g_MAX11131_device.Init(); // defined in #include MAX11131.h
whismanoid 0:3edb3708c8c5 6902 #endif // APPLICATION_MAX11131
whismanoid 0:3edb3708c8c5 6903
whismanoid 0:3edb3708c8c5 6904 #if APPLICATION_MAX5171 // InitializeConfiguration
whismanoid 0:3edb3708c8c5 6905 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6906 cmdLine_DAPLINKserial.serial().printf("\r\nMAX5171_Init()");
whismanoid 0:3edb3708c8c5 6907 # endif
whismanoid 0:3edb3708c8c5 6908 # if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 6909 cmdLine_microUSBserial.serial().printf("\r\nMAX5171_Init()");
whismanoid 0:3edb3708c8c5 6910 # endif
whismanoid 0:3edb3708c8c5 6911 int initResult = g_MAX5171_device.Init(); // defined in #include MAX5171.h
whismanoid 0:3edb3708c8c5 6912 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6913 cmdLine_DAPLINKserial.serial().printf("\r\nMAX5171_Init() returned %d\r\n", initResult);
whismanoid 0:3edb3708c8c5 6914 # endif
whismanoid 0:3edb3708c8c5 6915 # if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 6916 cmdLine_microUSBserial.serial().printf("\r\nMAX5171_Init() returned %d\r\n", initResult);
whismanoid 0:3edb3708c8c5 6917 # endif
whismanoid 0:3edb3708c8c5 6918 #endif // APPLICATION_MAX5171
whismanoid 0:3edb3708c8c5 6919
whismanoid 0:3edb3708c8c5 6920 #if APPLICATION_MAX11410 // InitializeConfiguration
whismanoid 0:3edb3708c8c5 6921 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6922 cmdLine_DAPLINKserial.serial().printf("\r\nMAX11410_Init()");
whismanoid 0:3edb3708c8c5 6923 # endif
whismanoid 0:3edb3708c8c5 6924 # if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 6925 cmdLine_microUSBserial.serial().printf("\r\nMAX11410_Init()");
whismanoid 0:3edb3708c8c5 6926 # endif
whismanoid 0:3edb3708c8c5 6927 int initResult = g_MAX11410_device.Init(); // defined in #include MAX11410.h
whismanoid 0:3edb3708c8c5 6928 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6929 cmdLine_DAPLINKserial.serial().printf("\r\nMAX11410_Init() returned %d\r\n", initResult);
whismanoid 0:3edb3708c8c5 6930 # endif
whismanoid 0:3edb3708c8c5 6931 # if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 6932 cmdLine_microUSBserial.serial().printf("\r\nMAX11410_Init() returned %d\r\n", initResult);
whismanoid 0:3edb3708c8c5 6933 # endif
whismanoid 0:3edb3708c8c5 6934 #endif // APPLICATION_MAX11410
whismanoid 0:3edb3708c8c5 6935
whismanoid 0:3edb3708c8c5 6936 #if APPLICATION_MAX12345 // InitializeConfiguration
whismanoid 0:3edb3708c8c5 6937 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6938 cmdLine_DAPLINKserial.serial().printf("\r\nMAX12345_Init()");
whismanoid 0:3edb3708c8c5 6939 # endif
whismanoid 0:3edb3708c8c5 6940 # if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 6941 cmdLine_microUSBserial.serial().printf("\r\nMAX12345_Init()");
whismanoid 0:3edb3708c8c5 6942 # endif
whismanoid 0:3edb3708c8c5 6943 int initResult = MAX12345_Init(); // defined in #include MAX12345.h
whismanoid 0:3edb3708c8c5 6944 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 6945 cmdLine_DAPLINKserial.serial().printf("\r\nMAX12345_Init() returned %d\r\n", initResult);
whismanoid 0:3edb3708c8c5 6946 # endif
whismanoid 0:3edb3708c8c5 6947 # if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 6948 cmdLine_microUSBserial.serial().printf("\r\nMAX12345_Init() returned %d\r\n", initResult);
whismanoid 0:3edb3708c8c5 6949 # endif
whismanoid 0:3edb3708c8c5 6950 #endif // APPLICATION_MAX12345
whismanoid 0:3edb3708c8c5 6951
whismanoid 0:3edb3708c8c5 6952 }
whismanoid 0:3edb3708c8c5 6953
whismanoid 0:3edb3708c8c5 6954 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 6955 // diagnostic rbg led GREEN
whismanoid 0:3edb3708c8c5 6956 void diagnostic_led_EOF()
whismanoid 0:3edb3708c8c5 6957 {
whismanoid 0:3edb3708c8c5 6958 #if USE_LEDS
whismanoid 0:3edb3708c8c5 6959 led1 = LED_ON; led2 = LED_ON; led3 = LED_OFF; // diagnostic rbg led RED+GREEN=YELLOW
whismanoid 0:3edb3708c8c5 6960 // TODO1: mbed-os-5.11: [Warning] 'static osStatus rtos::Thread::wait(uint32_t)' is deprecated: Static methods only affecting current thread cause confusion. Replaced by ThisThread::sleep_for. [since mbed-os-5.10] [-Wdeprecated-declarations]
whismanoid 0:3edb3708c8c5 6961 ThisThread::sleep_for(250); // [since mbed-os-5.10] vs Thread::wait(250);
whismanoid 0:3edb3708c8c5 6962 led1 = LED_OFF; led2 = LED_ON; led3 = LED_OFF; // diagnostic rbg led GREEN
whismanoid 0:3edb3708c8c5 6963 ThisThread::sleep_for(250); // [since mbed-os-5.10] vs Thread::wait(250);
whismanoid 0:3edb3708c8c5 6964 led1 = LED_ON; led2 = LED_ON; led3 = LED_OFF; // diagnostic rbg led RED+GREEN=YELLOW
whismanoid 0:3edb3708c8c5 6965 ThisThread::sleep_for(250); // [since mbed-os-5.10] vs Thread::wait(250);
whismanoid 0:3edb3708c8c5 6966 led1 = LED_OFF; led2 = LED_ON; led3 = LED_OFF; // diagnostic rbg led GREEN
whismanoid 0:3edb3708c8c5 6967 ThisThread::sleep_for(250); // [since mbed-os-5.10] vs Thread::wait(250);
whismanoid 0:3edb3708c8c5 6968 #endif // USE_LEDS
whismanoid 0:3edb3708c8c5 6969 }
whismanoid 0:3edb3708c8c5 6970
whismanoid 0:3edb3708c8c5 6971 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 6972 // Support commands that get handled immediately w/o waiting for EOL
whismanoid 0:3edb3708c8c5 6973 // handled as immediate command, do not append to buffer
whismanoid 0:3edb3708c8c5 6974 void on_immediate_0x21() // Unicode (U+0021) ! EXCLAMATION MARK
whismanoid 0:3edb3708c8c5 6975 {
whismanoid 0:3edb3708c8c5 6976 #if USE_LEDS
whismanoid 0:3edb3708c8c5 6977 led1 = LED_OFF; led2 = LED_OFF; led3 = LED_ON; // diagnostic rbg led BLUE
whismanoid 0:3edb3708c8c5 6978 #endif // USE_LEDS
whismanoid 0:3edb3708c8c5 6979 InitializeConfiguration();
whismanoid 0:3edb3708c8c5 6980 ThisThread::sleep_for(125); // [since mbed-os-5.10] vs Thread::wait(125);
whismanoid 0:3edb3708c8c5 6981 }
whismanoid 0:3edb3708c8c5 6982
whismanoid 0:3edb3708c8c5 6983 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 6984 // Support commands that get handled immediately w/o waiting for EOL
whismanoid 0:3edb3708c8c5 6985 // handled as immediate command, do not append to buffer
whismanoid 0:3edb3708c8c5 6986 void on_immediate_0x7b() // Unicode (U+007B) { LEFT CURLY BRACKET
whismanoid 0:3edb3708c8c5 6987 {
whismanoid 0:3edb3708c8c5 6988 //~ led1 = LED_OFF; led2 = LED_ON; led3 = LED_OFF; // diagnostic rbg led GREEN
whismanoid 0:3edb3708c8c5 6989 //~ InitializeConfiguration();
whismanoid 0:3edb3708c8c5 6990 //~ ThisThread::sleep_for(125); // [since mbed-os-5.10] vs Thread::wait(125);
whismanoid 0:3edb3708c8c5 6991 #if HAS_BUTTON2_DEMO_INTERRUPT
whismanoid 0:3edb3708c8c5 6992 onButton2FallingEdge();
whismanoid 0:3edb3708c8c5 6993 #endif
whismanoid 0:3edb3708c8c5 6994 }
whismanoid 0:3edb3708c8c5 6995
whismanoid 0:3edb3708c8c5 6996 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 6997 // Support commands that get handled immediately w/o waiting for EOL
whismanoid 0:3edb3708c8c5 6998 // handled as immediate command, do not append to buffer
whismanoid 0:3edb3708c8c5 6999 void on_immediate_0x7d() // Unicode (U+007D) } RIGHT CURLY BRACKET
whismanoid 0:3edb3708c8c5 7000 {
whismanoid 0:3edb3708c8c5 7001 //~ led1 = LED_OFF; led2 = LED_ON; led3 = LED_OFF; // diagnostic rbg led GREEN
whismanoid 0:3edb3708c8c5 7002 //~ InitializeConfiguration();
whismanoid 0:3edb3708c8c5 7003 //~ ThisThread::sleep_for(125); // [since mbed-os-5.10] vs Thread::wait(125);
whismanoid 0:3edb3708c8c5 7004 #if HAS_BUTTON1_DEMO_INTERRUPT
whismanoid 0:3edb3708c8c5 7005 onButton1FallingEdge();
whismanoid 0:3edb3708c8c5 7006 #endif
whismanoid 0:3edb3708c8c5 7007 }
whismanoid 0:3edb3708c8c5 7008
whismanoid 0:3edb3708c8c5 7009 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 7010 // based on example code: https://os.mbed.com/docs/v5.7/reference/pwmout.html
whismanoid 0:3edb3708c8c5 7011 int main()
whismanoid 0:3edb3708c8c5 7012 {
whismanoid 0:3edb3708c8c5 7013 //#ifdef SCOPE_TRIG_PIN
whismanoid 0:3edb3708c8c5 7014 // //pinMode(SCOPE_TRIG_PIN, OUTPUT);
whismanoid 0:3edb3708c8c5 7015 // scopeTrigPinP11 = 0; // digitalWrite(SCOPE_TRIG_PIN, LOW);
whismanoid 0:3edb3708c8c5 7016 // scopeTrigPinP11 = 1; // digitalWrite(SCOPE_TRIG_PIN, HIGH);
whismanoid 0:3edb3708c8c5 7017 //#endif // SCOPE_TRIG_PIN
whismanoid 0:3edb3708c8c5 7018
whismanoid 0:3edb3708c8c5 7019 // Configure serial ports
whismanoid 0:3edb3708c8c5 7020 #if defined(TARGET_MAX32630)
whismanoid 0:3edb3708c8c5 7021 // Note: DAPLINKserial interferes with the timer tick interrupt. Try faster baud rate?
whismanoid 0:3edb3708c8c5 7022 DAPLINKserial.baud(115200); // default 9600 baud
whismanoid 0:3edb3708c8c5 7023 //microUSBserial.baud(9600); // class USBSerial has no baud function
whismanoid 0:3edb3708c8c5 7024 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 7025 DAPLINKserial.printf("\r\n\r\nDAPLINK_SERIAL: main() startup\r\n");
whismanoid 0:3edb3708c8c5 7026 # endif
whismanoid 0:3edb3708c8c5 7027 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 7028 #elif defined(TARGET_MAX32625MBED)
whismanoid 0:3edb3708c8c5 7029 // MAX32625MBED crash if DAPLINKserial.baud(anything other than 9600 baud)
whismanoid 0:3edb3708c8c5 7030 // xxx DAPLINKserial.baud(115200); // default 9600 baud
whismanoid 0:3edb3708c8c5 7031 //microUSBserial.baud(9600); // class USBSerial has no baud function
whismanoid 0:3edb3708c8c5 7032 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 7033 DAPLINKserial.printf("\r\n\r\nDAPLINK_SERIAL: main() startup\r\n");
whismanoid 0:3edb3708c8c5 7034 # endif
whismanoid 0:3edb3708c8c5 7035 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 7036 #elif defined(TARGET_LPC1768)
whismanoid 0:3edb3708c8c5 7037 microUSBserial.baud(115200); // default 9600 baud
whismanoid 0:3edb3708c8c5 7038 #else
whismanoid 0:3edb3708c8c5 7039 // unknown target
whismanoid 0:3edb3708c8c5 7040 #endif
whismanoid 0:3edb3708c8c5 7041 #if USE_COMMAND_BUFFER
whismanoid 0:3edb3708c8c5 7042 # if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 7043 cmdLine_microUSBserial.clear();
whismanoid 0:3edb3708c8c5 7044 //~ cmdLine_microUSBserial.serial().printf("\r\n cmdLine_microUSBserial.serial().printf test\r\n");
whismanoid 0:3edb3708c8c5 7045 cmdLine_microUSBserial.onEOLcommandParser = main_menu_onEOLcommandParser;
whismanoid 0:3edb3708c8c5 7046 /// @todo CmdLine::set_immediate_handler(char, functionPointer_void_void_on_immediate_0x21);
whismanoid 0:3edb3708c8c5 7047 cmdLine_microUSBserial.on_immediate_0x21 = on_immediate_0x21;
whismanoid 0:3edb3708c8c5 7048 cmdLine_microUSBserial.on_immediate_0x7b = on_immediate_0x7b;
whismanoid 0:3edb3708c8c5 7049 cmdLine_microUSBserial.on_immediate_0x7d = on_immediate_0x7d;
whismanoid 0:3edb3708c8c5 7050 # endif
whismanoid 0:3edb3708c8c5 7051 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 7052 cmdLine_DAPLINKserial.clear();
whismanoid 0:3edb3708c8c5 7053 //~ cmdLine_DAPLINKserial.serial().printf("\r\n cmdLine_DAPLINKserial.serial().printf test\r\n");
whismanoid 0:3edb3708c8c5 7054 cmdLine_DAPLINKserial.onEOLcommandParser = main_menu_onEOLcommandParser;
whismanoid 0:3edb3708c8c5 7055 /// @todo CmdLine::set_immediate_handler(char, functionPointer_void_void_on_immediate_0x21);
whismanoid 0:3edb3708c8c5 7056 cmdLine_DAPLINKserial.on_immediate_0x21 = on_immediate_0x21;
whismanoid 0:3edb3708c8c5 7057 cmdLine_DAPLINKserial.on_immediate_0x7b = on_immediate_0x7b;
whismanoid 0:3edb3708c8c5 7058 cmdLine_DAPLINKserial.on_immediate_0x7d = on_immediate_0x7d;
whismanoid 0:3edb3708c8c5 7059 # endif
whismanoid 0:3edb3708c8c5 7060 #endif
whismanoid 0:3edb3708c8c5 7061
whismanoid 0:3edb3708c8c5 7062
whismanoid 0:3edb3708c8c5 7063 print_banner();
whismanoid 0:3edb3708c8c5 7064
whismanoid 0:3edb3708c8c5 7065 //#ifdef SCOPE_TRIG_PIN
whismanoid 0:3edb3708c8c5 7066 // scopePinP12 = 0;
whismanoid 0:3edb3708c8c5 7067 // scopePinP12 = 1;
whismanoid 0:3edb3708c8c5 7068 //#endif // SCOPE_TRIG_PIN
whismanoid 0:3edb3708c8c5 7069
whismanoid 0:3edb3708c8c5 7070 #if HAS_BUTTON1_DEMO_INTERRUPT
whismanoid 0:3edb3708c8c5 7071 # if HAS_BUTTON1_DEMO_INTERRUPT_POLLING
whismanoid 0:3edb3708c8c5 7072 # else
whismanoid 0:3edb3708c8c5 7073 button1.fall(&onButton1FallingEdge);
whismanoid 0:3edb3708c8c5 7074 # endif
whismanoid 0:3edb3708c8c5 7075 #endif // HAS_BUTTON1_DEMO_INTERRUPT
whismanoid 0:3edb3708c8c5 7076 #if HAS_BUTTON2_DEMO_INTERRUPT
whismanoid 0:3edb3708c8c5 7077 # if HAS_BUTTON1_DEMO_INTERRUPT_POLLING
whismanoid 0:3edb3708c8c5 7078 # else
whismanoid 0:3edb3708c8c5 7079 button2.fall(&onButton2FallingEdge);
whismanoid 0:3edb3708c8c5 7080 # endif
whismanoid 0:3edb3708c8c5 7081 #endif // HAS_BUTTON2_DEMO_INTERRUPT
whismanoid 0:3edb3708c8c5 7082
whismanoid 0:3edb3708c8c5 7083 #if defined(TARGET_MAX32630)
whismanoid 0:3edb3708c8c5 7084 // TODO1: timer tick needs to be the highest priority (priority 0, the default).
whismanoid 0:3edb3708c8c5 7085 // TODO1: DAPLINKserial interferes with the timer tick interrupt.
whismanoid 0:3edb3708c8c5 7086 // Lower the priority of the serial port interrupts to avoid disrupting motor operation.
whismanoid 0:3edb3708c8c5 7087 NVIC_SetPriority(UART0_IRQn, 2); // reservedBlueToothSerial(P0_1, P0_0) // 0=highest priority; 1=lower
whismanoid 0:3edb3708c8c5 7088 NVIC_SetPriority(UART1_IRQn, 2); // DAPLINKserial(P2_1, P2_0) // 0=highest priority; 1=lower
whismanoid 0:3edb3708c8c5 7089 NVIC_SetPriority(UART2_IRQn, 2); // reservedSerial(P3_1, P3_0) // 0=highest priority; 1=lower
whismanoid 0:3edb3708c8c5 7090 NVIC_SetPriority(UART3_IRQn, 2); // reservedSerial(P5_4, P5_3) // 0=highest priority; 1=lower
whismanoid 0:3edb3708c8c5 7091 NVIC_SetPriority(GPIO_P0_IRQn, 2); // 0=highest priority; 1=lower
whismanoid 0:3edb3708c8c5 7092 NVIC_SetPriority(GPIO_P1_IRQn, 2); // 0=highest priority; 1=lower
whismanoid 0:3edb3708c8c5 7093 NVIC_SetPriority(GPIO_P2_IRQn, 2); // 0=highest priority; 1=lower
whismanoid 0:3edb3708c8c5 7094 NVIC_SetPriority(GPIO_P3_IRQn, 2); // 0=highest priority; 1=lower
whismanoid 0:3edb3708c8c5 7095 NVIC_SetPriority(GPIO_P4_IRQn, 2); // 0=highest priority; 1=lower
whismanoid 0:3edb3708c8c5 7096 NVIC_SetPriority(GPIO_P5_IRQn, 2); // 0=highest priority; 1=lower
whismanoid 0:3edb3708c8c5 7097 NVIC_SetPriority(GPIO_P6_IRQn, 2); // 0=highest priority; 1=lower
whismanoid 0:3edb3708c8c5 7098 NVIC_SetPriority(GPIO_P7_IRQn, 2); // 0=highest priority; 1=lower
whismanoid 0:3edb3708c8c5 7099 NVIC_SetPriority(GPIO_P8_IRQn, 2); // 0=highest priority; 1=lower
whismanoid 0:3edb3708c8c5 7100 //~ NVIC_SetPriority(RTC0_IRQn, 0); // 0=highest priority; 1=lower
whismanoid 0:3edb3708c8c5 7101 //~ NVIC_SetPriority(RTC3_IRQn, 0); // 0=highest priority; 1=lower
whismanoid 0:3edb3708c8c5 7102 //~ NVIC_SetPriority(US_TIMER_IRQn, 0); // 0=highest priority; 1=lower
whismanoid 0:3edb3708c8c5 7103 #endif
whismanoid 0:3edb3708c8c5 7104
whismanoid 0:3edb3708c8c5 7105 #if HAS_SPI
whismanoid 0:3edb3708c8c5 7106 // spi init
whismanoid 0:3edb3708c8c5 7107 // mode | POL PHA
whismanoid 0:3edb3708c8c5 7108 // -----+--------
whismanoid 0:3edb3708c8c5 7109 // 0 | 0 0
whismanoid 0:3edb3708c8c5 7110 // 1 | 0 1
whismanoid 0:3edb3708c8c5 7111 // 2 | 1 0
whismanoid 0:3edb3708c8c5 7112 // 3 | 1 1
whismanoid 0:3edb3708c8c5 7113 //~ spi.format(8,0); // int bits_must_be_8, int mode=0_3 CPOL=0,CPHA=0 rising edge (initial default)
whismanoid 0:3edb3708c8c5 7114 //~ spi.format(8,1); // int bits_must_be_8, int mode=0_3 CPOL=0,CPHA=1 falling edge (initial default)
whismanoid 0:3edb3708c8c5 7115 //~ spi.format(8,2); // int bits_must_be_8, int mode=0_3 CPOL=1,CPHA=0 falling edge (initial default)
whismanoid 0:3edb3708c8c5 7116 //~ spi.format(8,3); // int bits_must_be_8, int mode=0_3 CPOL=1,CPHA=1 rising edge (initial default)
whismanoid 0:3edb3708c8c5 7117 //
whismanoid 0:3edb3708c8c5 7118 //~ spi.frequency(1000000); // int SCLK_Hz=1000000 = 1MHz (initial default)
whismanoid 0:3edb3708c8c5 7119 //~ spi.frequency(9600000); // int SCLK_Hz=9600000 = 9.6MHz = 96MHz/10
whismanoid 0:3edb3708c8c5 7120 //~ spi.frequency(10666666); // int SCLK_Hz=10666666 = 10.6MHz = 96MHz/9
whismanoid 0:3edb3708c8c5 7121 //~ spi.frequency(12000000); // int SCLK_Hz=12000000 = 12MHz = 96MHz/8
whismanoid 0:3edb3708c8c5 7122 //~ spi.frequency(13714286); // int SCLK_Hz=13714286 = 13.7MHz = 96MHz/7
whismanoid 0:3edb3708c8c5 7123 //~ spi.frequency(16000000); // int SCLK_Hz=16000000 = 16MHz = 96MHz/6
whismanoid 0:3edb3708c8c5 7124 //~ spi.frequency(19200000); // int SCLK_Hz=19200000 = 19.2MHz = 96MHz/5
whismanoid 0:3edb3708c8c5 7125 //~ spi.frequency(24000000); // int SCLK_Hz=24000000 = 24MHz = 96MHz/4
whismanoid 0:3edb3708c8c5 7126 //~ spi.frequency(32000000); // int SCLK_Hz=32000000 = 32MHz = 96MHz/3
whismanoid 0:3edb3708c8c5 7127 //~ spi.frequency(48000000); // int SCLK_Hz=48000000 = 48MHz = 96MHz/2
whismanoid 0:3edb3708c8c5 7128 // unspecified SPI device
whismanoid 0:3edb3708c8c5 7129 spi.format(8,g_SPI_dataMode); // int bits_must_be_8, int mode=0_3 CPOL=0,CPHA=0 rising edge (initial default)
whismanoid 0:3edb3708c8c5 7130 spi.frequency(g_SPI_SCLK_Hz); // int SCLK_Hz=1000000 = 1MHz (initial default)
whismanoid 0:3edb3708c8c5 7131 spi_cs = 1;
whismanoid 0:3edb3708c8c5 7132 #endif
whismanoid 0:3edb3708c8c5 7133
whismanoid 0:3edb3708c8c5 7134 #if HAS_I2C
whismanoid 0:3edb3708c8c5 7135 // i2c init
whismanoid 0:3edb3708c8c5 7136 // declare in narrower scope: MAX32625MBED I2C i2cMaster(...)
whismanoid 0:3edb3708c8c5 7137 // i2cMaster.frequency(g_I2C_SCL_Hz);
whismanoid 0:3edb3708c8c5 7138 #else
whismanoid 0:3edb3708c8c5 7139 // Ensure that the unused I2C pins do not interfere with analog inputs A4 and A5
whismanoid 0:3edb3708c8c5 7140 #if HAS_digitalInOut14
whismanoid 0:3edb3708c8c5 7141 // DigitalInOut digitalInOut14(P1_6, PIN_INPUT, PullUp, 1); // P1_6 TARGET_MAX32635MBED A4/SDA (10pin digital connector)
whismanoid 0:3edb3708c8c5 7142 digitalInOut14.input();
whismanoid 0:3edb3708c8c5 7143 #endif
whismanoid 0:3edb3708c8c5 7144 #if HAS_digitalInOut15
whismanoid 0:3edb3708c8c5 7145 // DigitalInOut digitalInOut15(P1_7, PIN_INPUT, PullUp, 1); // P1_7 TARGET_MAX32635MBED A5/SCL (10pin digital connector)
whismanoid 0:3edb3708c8c5 7146 digitalInOut15.input();
whismanoid 0:3edb3708c8c5 7147 #endif
whismanoid 0:3edb3708c8c5 7148 #if HAS_digitalInOut16
whismanoid 0:3edb3708c8c5 7149 // DigitalInOut mode can be one of PullUp, PullDown, PullNone, OpenDrain
whismanoid 0:3edb3708c8c5 7150 // PullUp-->3.4V, PullDown-->1.7V, PullNone-->3.5V, OpenDrain-->0.00V
whismanoid 0:3edb3708c8c5 7151 //DigitalInOut digitalInOut16(P3_4, PIN_INPUT, OpenDrain, 0); // P3_4 TARGET_MAX32635MBED A4/SDA (6pin analog connector)
whismanoid 0:3edb3708c8c5 7152 digitalInOut16.input();
whismanoid 0:3edb3708c8c5 7153 #endif
whismanoid 0:3edb3708c8c5 7154 #if HAS_digitalInOut17
whismanoid 0:3edb3708c8c5 7155 //DigitalInOut digitalInOut17(P3_5, PIN_INPUT, OpenDrain, 0); // P3_5 TARGET_MAX32635MBED A5/SCL (6pin analog connector)
whismanoid 0:3edb3708c8c5 7156 digitalInOut17.input();
whismanoid 0:3edb3708c8c5 7157 #endif
whismanoid 0:3edb3708c8c5 7158 #endif
whismanoid 0:3edb3708c8c5 7159
whismanoid 0:3edb3708c8c5 7160 #if USE_LEDS
whismanoid 0:3edb3708c8c5 7161 #if defined(TARGET_MAX32630)
whismanoid 0:3edb3708c8c5 7162 led1 = LED_ON; led2 = LED_OFF; led3 = LED_OFF; // diagnostic rbg led RED
whismanoid 0:3edb3708c8c5 7163 ThisThread::sleep_for(125); // [since mbed-os-5.10] vs Thread::wait(125);
whismanoid 0:3edb3708c8c5 7164 led1 = LED_OFF; led2 = LED_ON; led3 = LED_OFF; // diagnostic rbg led GREEN
whismanoid 0:3edb3708c8c5 7165 ThisThread::sleep_for(125); // [since mbed-os-5.10] vs Thread::wait(125);
whismanoid 0:3edb3708c8c5 7166 led1 = LED_OFF; led2 = LED_OFF; led3 = LED_ON; // diagnostic rbg led BLUE
whismanoid 0:3edb3708c8c5 7167 ThisThread::sleep_for(125); // [since mbed-os-5.10] vs Thread::wait(125);
whismanoid 0:3edb3708c8c5 7168 led1 = LED_ON; led2 = LED_ON; led3 = LED_ON; // diagnostic rbg led RED+GREEN+BLUE=WHITE
whismanoid 0:3edb3708c8c5 7169 ThisThread::sleep_for(125); // [since mbed-os-5.10] vs Thread::wait(125);
whismanoid 0:3edb3708c8c5 7170 led1 = LED_OFF; led2 = LED_ON; led3 = LED_ON; // diagnostic rbg led GREEN+BLUE=CYAN
whismanoid 0:3edb3708c8c5 7171 ThisThread::sleep_for(125); // [since mbed-os-5.10] vs Thread::wait(125);
whismanoid 0:3edb3708c8c5 7172 led1 = LED_ON; led2 = LED_OFF; led3 = LED_ON; // diagnostic rbg led RED+BLUE=MAGENTA
whismanoid 0:3edb3708c8c5 7173 ThisThread::sleep_for(125); // [since mbed-os-5.10] vs Thread::wait(125);
whismanoid 0:3edb3708c8c5 7174 led1 = LED_ON; led2 = LED_ON; led3 = LED_OFF; // diagnostic rbg led RED+GREEN=YELLOW
whismanoid 0:3edb3708c8c5 7175 ThisThread::sleep_for(125); // [since mbed-os-5.10] vs Thread::wait(125);
whismanoid 0:3edb3708c8c5 7176 led1 = LED_OFF; led2 = LED_OFF; led3 = LED_OFF; // diagnostic rbg led BLACK
whismanoid 0:3edb3708c8c5 7177 ThisThread::sleep_for(125); // [since mbed-os-5.10] vs Thread::wait(125);
whismanoid 0:3edb3708c8c5 7178 #elif defined(TARGET_MAX32625MBED)
whismanoid 0:3edb3708c8c5 7179 led1 = LED_ON; led2 = LED_OFF; led3 = LED_OFF; // diagnostic rbg led RED
whismanoid 0:3edb3708c8c5 7180 ThisThread::sleep_for(125); // [since mbed-os-5.10] vs Thread::wait(125);
whismanoid 0:3edb3708c8c5 7181 led1 = LED_OFF; led2 = LED_ON; led3 = LED_OFF; // diagnostic rbg led GREEN
whismanoid 0:3edb3708c8c5 7182 ThisThread::sleep_for(125); // [since mbed-os-5.10] vs Thread::wait(125);
whismanoid 0:3edb3708c8c5 7183 led1 = LED_OFF; led2 = LED_OFF; led3 = LED_ON; // diagnostic rbg led BLUE
whismanoid 0:3edb3708c8c5 7184 ThisThread::sleep_for(125); // [since mbed-os-5.10] vs Thread::wait(125);
whismanoid 0:3edb3708c8c5 7185 led1 = LED_ON; led2 = LED_ON; led3 = LED_ON; // diagnostic rbg led RED+GREEN+BLUE=WHITE
whismanoid 0:3edb3708c8c5 7186 ThisThread::sleep_for(125); // [since mbed-os-5.10] vs Thread::wait(125);
whismanoid 0:3edb3708c8c5 7187 led1 = LED_OFF; led2 = LED_ON; led3 = LED_ON; // diagnostic rbg led GREEN+BLUE=CYAN
whismanoid 0:3edb3708c8c5 7188 ThisThread::sleep_for(125); // [since mbed-os-5.10] vs Thread::wait(125);
whismanoid 0:3edb3708c8c5 7189 led1 = LED_ON; led2 = LED_OFF; led3 = LED_ON; // diagnostic rbg led RED+BLUE=MAGENTA
whismanoid 0:3edb3708c8c5 7190 ThisThread::sleep_for(125); // [since mbed-os-5.10] vs Thread::wait(125);
whismanoid 0:3edb3708c8c5 7191 led1 = LED_ON; led2 = LED_ON; led3 = LED_OFF; // diagnostic rbg led RED+GREEN=YELLOW
whismanoid 0:3edb3708c8c5 7192 ThisThread::sleep_for(125); // [since mbed-os-5.10] vs Thread::wait(125);
whismanoid 0:3edb3708c8c5 7193 led1 = LED_OFF; led2 = LED_OFF; led3 = LED_OFF; // diagnostic rbg led BLACK
whismanoid 0:3edb3708c8c5 7194 ThisThread::sleep_for(125); // [since mbed-os-5.10] vs Thread::wait(125);
whismanoid 0:3edb3708c8c5 7195 #else // not defined(TARGET_LPC1768 etc.)
whismanoid 0:3edb3708c8c5 7196 led1 = LED_ON;
whismanoid 0:3edb3708c8c5 7197 led2 = LED_OFF;
whismanoid 0:3edb3708c8c5 7198 led3 = LED_OFF;
whismanoid 0:3edb3708c8c5 7199 led4 = LED_OFF;
whismanoid 0:3edb3708c8c5 7200 ThisThread::sleep_for(75); // [since mbed-os-5.10] vs Thread::wait(75);
whismanoid 0:3edb3708c8c5 7201 //led1 = LED_ON;
whismanoid 0:3edb3708c8c5 7202 led2 = LED_ON;
whismanoid 0:3edb3708c8c5 7203 ThisThread::sleep_for(75); // [since mbed-os-5.10] vs Thread::wait(75);
whismanoid 0:3edb3708c8c5 7204 led1 = LED_OFF;
whismanoid 0:3edb3708c8c5 7205 //led2 = LED_ON;
whismanoid 0:3edb3708c8c5 7206 led3 = LED_ON;
whismanoid 0:3edb3708c8c5 7207 ThisThread::sleep_for(75); // [since mbed-os-5.10] vs Thread::wait(75);
whismanoid 0:3edb3708c8c5 7208 led2 = LED_OFF;
whismanoid 0:3edb3708c8c5 7209 //led3 = LED_ON;
whismanoid 0:3edb3708c8c5 7210 led4 = LED_ON;
whismanoid 0:3edb3708c8c5 7211 ThisThread::sleep_for(75); // [since mbed-os-5.10] vs Thread::wait(75);
whismanoid 0:3edb3708c8c5 7212 led3 = LED_OFF;
whismanoid 0:3edb3708c8c5 7213 led4 = LED_ON;
whismanoid 0:3edb3708c8c5 7214 //
whismanoid 0:3edb3708c8c5 7215 #endif // target definition
whismanoid 0:3edb3708c8c5 7216 #endif
whismanoid 0:3edb3708c8c5 7217
whismanoid 0:3edb3708c8c5 7218 // cmd_TE();
whismanoid 0:3edb3708c8c5 7219
whismanoid 0:3edb3708c8c5 7220 #if USE_LEDS
whismanoid 0:3edb3708c8c5 7221 rgb_led.white(); // diagnostic rbg led RED+GREEN+BLUE=WHITE
whismanoid 0:3edb3708c8c5 7222 #endif // USE_LEDS
whismanoid 0:3edb3708c8c5 7223 InitializeConfiguration();
whismanoid 0:3edb3708c8c5 7224
whismanoid 0:3edb3708c8c5 7225 while (1) {
whismanoid 0:3edb3708c8c5 7226 #if HAS_BUTTON1_DEMO_INTERRUPT_POLLING
whismanoid 0:3edb3708c8c5 7227 // avoid runtime error on button1 press [mbed-os-5.11]
whismanoid 0:3edb3708c8c5 7228 // instead of using InterruptIn, use DigitalIn and poll in main while(1)
whismanoid 0:3edb3708c8c5 7229 # if HAS_BUTTON1_DEMO_INTERRUPT
whismanoid 0:3edb3708c8c5 7230 static int button1_value_prev = 1;
whismanoid 0:3edb3708c8c5 7231 static int button1_value_now = 1;
whismanoid 0:3edb3708c8c5 7232 button1_value_prev = button1_value_now;
whismanoid 0:3edb3708c8c5 7233 button1_value_now = button1.read();
whismanoid 0:3edb3708c8c5 7234 if ((button1_value_prev - button1_value_now) == 1)
whismanoid 0:3edb3708c8c5 7235 {
whismanoid 0:3edb3708c8c5 7236 // on button1 falling edge (button1 press)
whismanoid 0:3edb3708c8c5 7237 onButton1FallingEdge();
whismanoid 0:3edb3708c8c5 7238 }
whismanoid 0:3edb3708c8c5 7239 # endif // HAS_BUTTON1_DEMO_INTERRUPT
whismanoid 0:3edb3708c8c5 7240 # if HAS_BUTTON2_DEMO_INTERRUPT
whismanoid 0:3edb3708c8c5 7241 static int button2_value_prev = 1;
whismanoid 0:3edb3708c8c5 7242 static int button2_value_now = 1;
whismanoid 0:3edb3708c8c5 7243 button2_value_prev = button2_value_now;
whismanoid 0:3edb3708c8c5 7244 button2_value_now = button2.read();
whismanoid 0:3edb3708c8c5 7245 if ((button2_value_prev - button2_value_now) == 1)
whismanoid 0:3edb3708c8c5 7246 {
whismanoid 0:3edb3708c8c5 7247 // on button2 falling edge (button2 press)
whismanoid 0:3edb3708c8c5 7248 onButton2FallingEdge();
whismanoid 0:3edb3708c8c5 7249 }
whismanoid 0:3edb3708c8c5 7250 # endif // HAS_BUTTON2_DEMO_INTERRUPT
whismanoid 0:3edb3708c8c5 7251 #endif
whismanoid 0:3edb3708c8c5 7252 #if USE_COMMAND_BUFFER
whismanoid 0:3edb3708c8c5 7253 //cmdLine_update();
whismanoid 0:3edb3708c8c5 7254 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 7255 // GREEN = DAPLINKserial
whismanoid 0:3edb3708c8c5 7256 //~ led1 = LED_OFF; led2 = LED_ON; led3 = LED_OFF; // diagnostic rbg led GREEN
whismanoid 0:3edb3708c8c5 7257 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 7258 if (DAPLINKserial.readable()) {
whismanoid 0:3edb3708c8c5 7259 cmdLine_DAPLINKserial.append(DAPLINKserial.getc());
whismanoid 0:3edb3708c8c5 7260 }
whismanoid 0:3edb3708c8c5 7261 # endif // HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 7262 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 7263 // BLUE = reading ADC
whismanoid 0:3edb3708c8c5 7264 //~ led1 = LED_OFF; led2 = LED_OFF; led3 = LED_ON; // diagnostic rbg led BLUE
whismanoid 0:3edb3708c8c5 7265 // CS=%d) set comTickLimit %d..%d CSA) comTickLimit is set by AIN0
whismanoid 0:3edb3708c8c5 7266 //~ if (is_comTickLimit_from_AIN0) {
whismanoid 0:3edb3708c8c5 7267 //~ update_comTickLimit_from_AIN0_AIN4();
whismanoid 0:3edb3708c8c5 7268 //~ }
whismanoid 0:3edb3708c8c5 7269 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 7270 // YELLOW = microUSBserial
whismanoid 0:3edb3708c8c5 7271 //~ led1 = LED_ON; led2 = LED_ON; led3 = LED_OFF; // diagnostic rbg led RED+GREEN=YELLOW
whismanoid 0:3edb3708c8c5 7272 # if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 7273 if (microUSBserial.readable()) {
whismanoid 0:3edb3708c8c5 7274 int c = microUSBserial.getc();
whismanoid 0:3edb3708c8c5 7275 cmdLine_microUSBserial.append(c);
whismanoid 0:3edb3708c8c5 7276 #if IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 7277 # if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 7278 cmdLine_DAPLINKserial.serial().printf("%c", c);
whismanoid 0:3edb3708c8c5 7279 # endif // HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 7280 #endif // IGNORE_AT_COMMANDS
whismanoid 0:3edb3708c8c5 7281 //
whismanoid 0:3edb3708c8c5 7282 }
whismanoid 0:3edb3708c8c5 7283 # endif // HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 7284 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 7285 // MAGENTA = reading ADC
whismanoid 0:3edb3708c8c5 7286 //~ led1 = LED_ON; led2 = LED_OFF; led3 = LED_ON; // diagnostic rbg led RED+BLUE=MAGENTA
whismanoid 0:3edb3708c8c5 7287 // CP=%d) set pwmCompare %d..%d CPA) PWM is set by AIN1
whismanoid 0:3edb3708c8c5 7288 //~ if (is_pwmCompare_from_AIN1) {
whismanoid 0:3edb3708c8c5 7289 //~ update_pwmCompare_from_AIN1_AIN5();
whismanoid 0:3edb3708c8c5 7290 //~ }
whismanoid 0:3edb3708c8c5 7291 //--------------------------------------------------
whismanoid 0:3edb3708c8c5 7292 // CYAN = other while loop stuff?
whismanoid 0:3edb3708c8c5 7293 //~ led1 = LED_OFF; led2 = LED_ON; led3 = LED_ON; // diagnostic rbg led GREEN+BLUE=CYAN
whismanoid 0:3edb3708c8c5 7294 //~ rgb_led.red(); // diagnostic rbg led RED
whismanoid 0:3edb3708c8c5 7295 //~ rgb_led.green(); // diagnostic rbg led GREEN
whismanoid 0:3edb3708c8c5 7296 //~ rgb_led.blue(); // diagnostic rbg led BLUE
whismanoid 0:3edb3708c8c5 7297 //~ rgb_led.white(); // diagnostic rbg led RED+GREEN+BLUE=WHITE
whismanoid 0:3edb3708c8c5 7298 //~ rgb_led.cyan(); // diagnostic rbg led GREEN+BLUE=CYAN
whismanoid 0:3edb3708c8c5 7299 //~ rgb_led.magenta(); // diagnostic rbg led RED+BLUE=MAGENTA
whismanoid 0:3edb3708c8c5 7300 //~ rgb_led.yellow(); // diagnostic rbg led RED+GREEN=YELLOW
whismanoid 0:3edb3708c8c5 7301 //~ rgb_led.black(); // diagnostic rbg led BLACK
whismanoid 0:3edb3708c8c5 7302 #else // USE_COMMAND_BUFFER
whismanoid 0:3edb3708c8c5 7303 //
whismanoid 0:3edb3708c8c5 7304 // character echo demo stuff; sandbox
whismanoid 0:3edb3708c8c5 7305 //
whismanoid 0:3edb3708c8c5 7306 // char* gets(char* buf, int size); // equivalent to char *gets_s( char *str, rsize_t n )
whismanoid 0:3edb3708c8c5 7307 // Reads characters from stdin until a newline is found or end-of-file occurs.
whismanoid 0:3edb3708c8c5 7308 // Writes only at most n-1 characters into the array pointed to by str,
whismanoid 0:3edb3708c8c5 7309 // and always writes the terminating null character (unless str is a null pointer).
whismanoid 0:3edb3708c8c5 7310 // The newline character, is discarded and not written to the buffer.
whismanoid 0:3edb3708c8c5 7311 if (gets(line_buffer, sizeof(line_buffer)))
whismanoid 0:3edb3708c8c5 7312 {
whismanoid 0:3edb3708c8c5 7313 puts(line_buffer);
whismanoid 0:3edb3708c8c5 7314 }
whismanoid 0:3edb3708c8c5 7315
whismanoid 0:3edb3708c8c5 7316 // serial port demo -- echo from DAPLINKserial to microUSBserial
whismanoid 0:3edb3708c8c5 7317 #if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 7318 if (DAPLINKserial.readable()) {
whismanoid 0:3edb3708c8c5 7319 int c = DAPLINKserial.getc();
whismanoid 0:3edb3708c8c5 7320 led2 = (c & 1);
whismanoid 0:3edb3708c8c5 7321 #if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 7322 DAPLINKserial.putc(c);
whismanoid 0:3edb3708c8c5 7323 #endif
whismanoid 0:3edb3708c8c5 7324 #if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 7325 microUSBserial.putc(c);
whismanoid 0:3edb3708c8c5 7326 #endif
whismanoid 0:3edb3708c8c5 7327 // command processing
whismanoid 0:3edb3708c8c5 7328 if (c == '?') {
whismanoid 0:3edb3708c8c5 7329 print_banner();
whismanoid 0:3edb3708c8c5 7330 }
whismanoid 0:3edb3708c8c5 7331 }
whismanoid 0:3edb3708c8c5 7332 #endif // HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 7333 // serial port demo -- echo from microUSBserial to DAPLINKserial
whismanoid 0:3edb3708c8c5 7334 #if HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 7335 if (microUSBserial.readable()) {
whismanoid 0:3edb3708c8c5 7336 int c = microUSBserial.getc();
whismanoid 0:3edb3708c8c5 7337 led1 = (c & 1);
whismanoid 0:3edb3708c8c5 7338 #if HAS_DAPLINK_SERIAL
whismanoid 0:3edb3708c8c5 7339 DAPLINKserial.putc(c);
whismanoid 0:3edb3708c8c5 7340 #endif
whismanoid 0:3edb3708c8c5 7341 microUSBserial.putc(c);
whismanoid 0:3edb3708c8c5 7342 // command processing
whismanoid 0:3edb3708c8c5 7343 if (c == '?') {
whismanoid 0:3edb3708c8c5 7344 print_banner();
whismanoid 0:3edb3708c8c5 7345 }
whismanoid 0:3edb3708c8c5 7346 }
whismanoid 0:3edb3708c8c5 7347 #endif // HAS_MICROUSBSERIAL
whismanoid 0:3edb3708c8c5 7348 #endif // USE_COMMAND_BUFFER
whismanoid 0:3edb3708c8c5 7349 } // while(1)
whismanoid 0:3edb3708c8c5 7350 }