Arduino to Peripheral Module adapter library

Dependents:   ARD2PMD_WebServer

This library assigns the proper pins for an Arduino compatible board with the ard2pmd adapter board.

  • mux I2C pins mux(D14, D15)

Digital I/O

pmd[8] is an array of pointers to the DigitalInOut objects

IndexNamePmod
0pa11
1pa22
2pa33
3pa44
4pb17
5pb28
6pb39
7pb410

MAX14661 Multiplexer Abstraction

mux_a[17] is an array of integers representing the bit mask of a multiplexer switch arranged in Arduino order

IndexPinName
0D0RX
1D1TX
2D2D3
3D3D4
4D4PB1
5D5PB2
6D6PB3
7D7PB4
8D8D8
9D9D9
10D10PA1
11D11PA2
12D12PA3
13D13PA4
14D14SDA
15D15SCL
16na0

mux_p[9] is an array of integers representing the bit mask of a multiplexer switch arranged in Pmod order

IndexPinName
0D10PA1
1D11PA2
2D12PA3
3D13PA4
4D4PB1
5D5PB2
6D6PB3
7D7PB4
8na0
Revision:
0:d42cfc64e43e
Child:
2:722a0e1df9a9
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/ARD2PMD.h	Mon Feb 10 03:10:39 2014 +0000
@@ -0,0 +1,97 @@
+/* ARD2PMD Board Driver Library
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a copy of this software
+ * and associated documentation files (the "Software"), to deal in the Software without restriction,
+ * including without limitation the rights to use, copy, modify, merge, publish, distribute,
+ * sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is
+ * furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in all copies or
+ * substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
+ * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+ * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
+ * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+ */
+
+#ifndef ARD2PMD_H
+#define ARD2PMD_H
+
+#include "mbed.h"
+#include "MAX14661.h"
+
+
+/** ARD2PMD Library, Provides utilities for configuring the Maxim ARD2PMD Board
+ *
+ * Example:
+ * @code
+ * // Configure board to pass UART signals to peripheral connector.
+ *
+ * #include "ARD2PMD.h"
+ *
+ * ARD2PMD a2p(p28, p27);
+ *
+ * int main() {
+ *     a2p.setMux((ARD2PMD::RX | ARD2PMD::PA3), (ARD2PMD::TX | ARD2PMD::PA2)); 
+ * }
+ * @endcode
+ */
+class ARD2PMD
+{
+public:
+
+    /** Create a ARD2PMD interface
+     *
+     * @param sda I2C data line pin
+     * @param scl I2C clock line pin
+     * @param addr MAX14661 I2C address
+     */
+    ARD2PMD(PinName sda, PinName scl, int addr = 0x98);
+
+    ~ARD2PMD();
+
+    /** Name the register addresses
+    */
+    enum MUXsignals {
+        RX = MAX14661::SW01,
+        TX = MAX14661::SW02,
+        D2 = MAX14661::SW03,
+        D3 = MAX14661::SW04,
+        PB1 = MAX14661::SW05,
+        PB2 = MAX14661::SW06,
+        PB3 = MAX14661::SW07,
+        PB4 = MAX14661::SW08,
+        D8 = MAX14661::SW09,
+        D9 = MAX14661::SW10,
+        PA1 = MAX14661::SW11,
+        PA2 = MAX14661::SW12,
+        PA3 = MAX14661::SW13,
+        PA4 = MAX14661::SW14,
+        SDA = MAX14661::SW15,
+        SCL = MAX14661::SW16
+    };
+
+    /** Opens all mux switches
+     */
+    void clearMux();
+
+    /** Simultaneously sets both mux channels
+     *
+     *  @param chA the signals to route through channel A
+     *  @param chB the signals to route through channel B
+     */
+    void setMux(int chA, int chB);
+
+    /** Convert peripheral pin index to mux bit
+     *
+     *  @param index the index [7-0] of desired pin on the peripheral connector
+     */
+    int iToMux(int index);
+
+private:
+    MAX14661 _mux;
+};
+
+#endif
\ No newline at end of file