aboutsummaryrefslogtreecommitdiffstats
path: root/libraries/Wire/WireBase.h
diff options
context:
space:
mode:
Diffstat (limited to 'libraries/Wire/WireBase.h')
-rw-r--r--libraries/Wire/WireBase.h144
1 files changed, 144 insertions, 0 deletions
diff --git a/libraries/Wire/WireBase.h b/libraries/Wire/WireBase.h
new file mode 100644
index 0000000..555cbaf
--- /dev/null
+++ b/libraries/Wire/WireBase.h
@@ -0,0 +1,144 @@
+/******************************************************************************
+ * The MIT License
+ *
+ * Copyright (c) 2010 LeafLabs LLC.
+ *
+ * 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.
+ *****************************************************************************/
+
+/**
+ * @file WireBase.h
+ * @author Trystan Jones <crenn6977@gmail.com>
+ * @brief Wire library, following the majority of the interface from Arduino.
+ * Provides a 'standard' interface to I2C (two-wire) communication for
+ * derived classes.
+ */
+
+/*
+ * Library created by crenn to allow a system which would provide users the
+ * 'standardised' Arduino method for interfacing with I2C devices regardless of
+ * whether it is I2C hardware or emulating software.
+ */
+
+#include "wirish.h"
+
+#ifndef _WIREBASE_H_
+#define _WIREBASE_H_
+
+#include "i2c.h"
+
+#define WIRE_BUFSIZ 32
+
+/* return codes from endTransmission() */
+#define SUCCESS 0 /* transmission was successful */
+#define EDATA 1 /* too much data */
+#define ENACKADDR 2 /* received nack on transmit of address */
+#define ENACKTRNS 3 /* received nack on transmit of data */
+#define EOTHER 4 /* other error */
+
+class WireBase { // Abstraction is awesome!
+protected:
+ i2c_msg itc_msg;
+ uint8 rx_buf[WIRE_BUFSIZ]; /* receive buffer */
+ uint8 rx_buf_idx; /* first unread idx in rx_buf */
+ uint8 rx_buf_len; /* number of bytes read */
+
+ uint8 tx_buf[WIRE_BUFSIZ]; /* transmit buffer */
+ uint8 tx_buf_idx; // next idx available in tx_buf, -1 overflow
+ boolean tx_buf_overflow;
+
+ // Force derived classes to define process function
+ virtual uint8 process() = 0;
+public:
+ WireBase() {}
+ ~WireBase() {}
+
+ /*
+ * Initialises the class interface
+ */
+ // Allow derived classes to overwrite begin function
+ virtual void begin(uint8 = 0x00);
+
+ /*
+ * Sets up the transmission message to be processed
+ */
+ void beginTransmission(uint8);
+
+ /*
+ * Allow only 8 bit addresses to be used
+ */
+ void beginTransmission(int);
+
+ /*
+ * Call the process function to process the message if the TX buffer has not
+ * overflowed.
+ */
+ uint8 endTransmission(void);
+
+ /*
+ * Request bytes from a slave device and process the request, storing into the
+ * receiving buffer.
+ */
+ uint8 requestFrom(uint8, int);
+
+ /*
+ * Allow only 8 bit addresses to be used when requesting bytes
+ */
+ uint8 requestFrom(int, int);
+
+ /*
+ * Stack up bytes to be sent when transmitting
+ */
+ void send(uint8);
+
+ /*
+ * Stack up bytes from the array to be sent when transmitting
+ */
+ void send(uint8*, int);
+
+ /*
+ * Ensure that a sending data will only be 8-bit bytes
+ */
+ void send(int);
+
+ /*
+ * Ensure that an array sending data will only be 8-bit bytes
+ */
+ void send(int*, int);
+
+ /*
+ * Stack up bytes from a string to be sent when transmitting
+ */
+ void send(char*);
+
+ /*
+ * Return the amount of bytes that is currently in the receiving buffer
+ */
+ uint8 available();
+
+ /*
+ * Return the value of byte in the receiving buffer that is currently being
+ * pointed to
+ */
+ uint8 receive();
+};
+
+#endif // _WIREBASE_H_ \ No newline at end of file