srf08 library working with RTOS from BenderII

Revision:
0:70df4930eee9
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/SRF08.cpp	Tue Aug 11 13:01:45 2015 +0000
@@ -0,0 +1,150 @@
+/*
+Copyright (c) 2012 Brent Dekker
+ 
+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.
+*/
+ 
+#include "SRF08.h"
+ 
+/*
+ * Constructor: SRF08
+ * Args:
+ * Returns:     void
+ * Description: Creates an instance of the SRF08 to communicate with a sRF08 module
+ */
+SRF08::SRF08(PinName SDA, PinName SCL, int i2cAddress) :
+        i2cMod(SDA, SCL), 
+        i2cAddress(i2cAddress),  
+        rangingBusy(false) {
+ 
+}
+ 
+/*
+ * Function:    startRanging
+ * Args:        void
+ * Returns:     void
+ * Description: Sends command to module to start ranging.
+ */
+void SRF08::startRanging() {
+    //Create a two byte command. The first first byte is the register address
+    // on the SRF08 to write to. The second byte is the command which is written
+    // to that address ("Start ranging in cm" in this case).
+    const char command[] = {0x00, 0x51};
+    i2cMod.write(i2cAddress, command, 2);
+    this->rangingBusy = true;
+    Thread::wait(70);
+    setRangingFinished();
+}
+ 
+/*
+ * Function:    rangingFinished
+ * Args:        void
+ * Returns:     Bool: whether ranging is finished
+ * Description: Checks if the ranging process on the module is finished
+ */
+bool SRF08::rangingFinished() {
+    if(this->rangingBusy) return false;
+    return true;
+}
+ 
+/*
+ * Function:    getRange
+ * Args:        void
+ * Returns:     int range
+ * Description: Range in cm. This function should only be called when ranging is finished, otherwise previous value is returned
+ */
+int SRF08::getRange() {
+    while (!rangingFinished() ) 
+        Thread::wait(10);   //Wait until ranging is finished
+    const char command[]  = {0x02};           //Address of range register
+    char response[] = {0x00, 0x00};
+    i2cMod.write(i2cAddress, command, 1, 1);  //Send command
+    i2cMod.read(i2cAddress, response, 2);     //Read 16bits result
+    int range = (response[0]<<8)+response[1]; //Shift two bytes into int
+    return range;                             //Return int range
+}
+ 
+/*
+ * Function:    readLightIntensity
+ * Args:        void
+ * Returns:     int lightIntensity
+ * Description: Reads the lightIntensity from the module
+ *              The light intensity is updated if a range command is sent, so don't use
+ *              this function only
+ */
+int SRF08::getLightIntensity() {
+    const char command[] = {0x01};           //Light intensity register
+    char response[] = {0x00};
+    i2cMod.write(i2cAddress, command, 1, 1); //Send command
+    i2cMod.read(i2cAddress, response, 1);    //Read response
+    int lightIntensity = response[0];
+    return lightIntensity;
+}
+ 
+/*
+ * Function:    setRangeRegister
+ * Args:        rangeVal
+ * Returns:     void
+ * Description: Sets the maximum range for which the module waits for an echo
+ *              The range is ((rangeVal x 43mm) + 43mm)
+ *              The max range is about six meters
+ */
+void SRF08::setRangeRegister(unsigned char rangeVal) {
+    while (!rangingFinished() ) 
+        Thread::wait(10);                    //Wait until ranging is finished
+    char command[] = {0x02, rangeVal};       //Range register
+    i2cMod.write(i2cAddress, command, 2);    //Send command
+}
+ 
+ 
+//Function setMaxGainRegister
+void SRF08::setMaxGainRegister(unsigned char gainVal) {
+    while (!rangingFinished() ) 
+        Thread::wait(10);                    //Wait until ranging is finished
+    char command[] = {0x01, gainVal};        //Max gain register
+    i2cMod.write(i2cAddress, command, 2);    //Send command
+}
+ 
+/*
+ * Function:    setAddress
+ * Args:        address
+ * Returns:     void
+ * Description: Sets the address of the module on the I2C bus. The factory default address is 0x0E (224)
+ *                  The address can have the following values:
+ *                      E0 | E2 | E4 | E6 ... FC | FE
+ */
+void SRF08::setAddress(int address) {
+    //Send address change sequence
+    char command[] = {0x00, 0xA0};
+    i2cMod.write(i2cAddress, command, 2);
+    command[1] = 0xAA;
+    i2cMod.write(i2cAddress, command, 2);
+    command[1] = 0xA5;
+    i2cMod.write(i2cAddress, command, 2);
+    command[1] = address;
+    i2cMod.write(i2cAddress, command, 2);
+    //Save the updated address
+    i2cAddress = address;
+}
+ 
+//Small helper function for Timeout object
+void SRF08::setRangingFinished() {
+    this->rangingBusy = false;
+}
+            
\ No newline at end of file