Code for our FYDP -only one IMU works right now -RTOS is working

Dependencies:   mbed

Committer:
majik
Date:
Wed Mar 18 22:23:48 2015 +0000
Revision:
0:964eb6a2ef00
This is our FYDP code, but only one IMU works with the RTOS.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
majik 0:964eb6a2ef00 1 /*
majik 0:964eb6a2ef00 2 Copyright (c) 2011 Andy Kirkham
majik 0:964eb6a2ef00 3
majik 0:964eb6a2ef00 4 Permission is hereby granted, free of charge, to any person obtaining a copy
majik 0:964eb6a2ef00 5 of this software and associated documentation files (the "Software"), to deal
majik 0:964eb6a2ef00 6 in the Software without restriction, including without limitation the rights
majik 0:964eb6a2ef00 7 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
majik 0:964eb6a2ef00 8 copies of the Software, and to permit persons to whom the Software is
majik 0:964eb6a2ef00 9 furnished to do so, subject to the following conditions:
majik 0:964eb6a2ef00 10
majik 0:964eb6a2ef00 11 The above copyright notice and this permission notice shall be included in
majik 0:964eb6a2ef00 12 all copies or substantial portions of the Software.
majik 0:964eb6a2ef00 13
majik 0:964eb6a2ef00 14 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
majik 0:964eb6a2ef00 15 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
majik 0:964eb6a2ef00 16 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
majik 0:964eb6a2ef00 17 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
majik 0:964eb6a2ef00 18 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
majik 0:964eb6a2ef00 19 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
majik 0:964eb6a2ef00 20 THE SOFTWARE.
majik 0:964eb6a2ef00 21
majik 0:964eb6a2ef00 22 @file example3b.cpp
majik 0:964eb6a2ef00 23 @purpose Demos a simple filter.
majik 0:964eb6a2ef00 24 @version see ChangeLog.c
majik 0:964eb6a2ef00 25 @author Andy Kirkham
majik 0:964eb6a2ef00 26 */
majik 0:964eb6a2ef00 27
majik 0:964eb6a2ef00 28 /*
majik 0:964eb6a2ef00 29 This example shows how to use the new callback system. In the old system
majik 0:964eb6a2ef00 30 Mbed's FunctionPointer[1] type was used to store abd make calls to callbacks.
majik 0:964eb6a2ef00 31 However, that limits the callback function prototype to void func(void);
majik 0:964eb6a2ef00 32 which means we cannot pass parameters.
majik 0:964eb6a2ef00 33
majik 0:964eb6a2ef00 34 This latest version of MODSERIAL now uses its own callback object. This allows
majik 0:964eb6a2ef00 35 the passing of a pointer to a class that holds information about the MODSERIAL
majik 0:964eb6a2ef00 36 object making the callback. As of version 1.18 one critcal piece of information
majik 0:964eb6a2ef00 37 is passed, a pointer to the MODSERIAL object. This allows callbacks to use the
majik 0:964eb6a2ef00 38 MODSERIAL functions and data.
majik 0:964eb6a2ef00 39
majik 0:964eb6a2ef00 40 Additionally, since MODSERIAL and the callback parameter class MODSERIAL_IRQ_INFO
majik 0:964eb6a2ef00 41 are friends, MODSERIAL_IRQ_INFO can access the protected functions of MODSERIAL.
majik 0:964eb6a2ef00 42 This is used to ensure functions that can only be called during a callback
majik 0:964eb6a2ef00 43 can be invoked from a callback.
majik 0:964eb6a2ef00 44
majik 0:964eb6a2ef00 45 [1] http://mbed.org/projects/libraries/svn/mbed/trunk/FunctionPointer.h
majik 0:964eb6a2ef00 46 */
majik 0:964eb6a2ef00 47
majik 0:964eb6a2ef00 48
majik 0:964eb6a2ef00 49 #ifdef COMPILE_EXAMPLE3_CODE_MODSERIAL
majik 0:964eb6a2ef00 50
majik 0:964eb6a2ef00 51 #include "mbed.h"
majik 0:964eb6a2ef00 52 #include "MODSERIAL.h"
majik 0:964eb6a2ef00 53
majik 0:964eb6a2ef00 54 void rxCallback(MODSERIAL_IRQ_INFO *info) {
majik 0:964eb6a2ef00 55
majik 0:964eb6a2ef00 56 // Get the pointer to our MODSERIAL object that invoked this callback.
majik 0:964eb6a2ef00 57 MODSERIAL *pc = info->serial;
majik 0:964eb6a2ef00 58
majik 0:964eb6a2ef00 59 // info->serial points at the MODSERIAL instance so we can use it to call
majik 0:964eb6a2ef00 60 // any of the public MODSERIAL functions that are normally available. So
majik 0:964eb6a2ef00 61 // there's now no need to use the global version (pc in our case) inside
majik 0:964eb6a2ef00 62 // callback functions.
majik 0:964eb6a2ef00 63 char c = pc->rxGetLastChar(); // Where local pc variable is a pointer to the global MODSERIAL pc object.
majik 0:964eb6a2ef00 64
majik 0:964eb6a2ef00 65 // The following is rather daft but demos the point.
majik 0:964eb6a2ef00 66 // Don't allow the letter "A" go into the RX buffer.
majik 0:964eb6a2ef00 67 // Basically acts as a filter to remove the letter "A"
majik 0:964eb6a2ef00 68 // if it goes into the RX buffer.
majik 0:964eb6a2ef00 69 if (c == 'A') {
majik 0:964eb6a2ef00 70 // Note, we call the MODSERIAL_IRQ_INFO::rxDiscardLastChar() public function which
majik 0:964eb6a2ef00 71 // is permitted access to the protected version of MODSERIAL::rxDiscardLastChar()
majik 0:964eb6a2ef00 72 // within MODSERIAL (because they are friends). This ensures rxDiscardLastChar()
majik 0:964eb6a2ef00 73 // can only be called within an rxCallback function.
majik 0:964eb6a2ef00 74 info->rxDiscardLastChar();
majik 0:964eb6a2ef00 75 }
majik 0:964eb6a2ef00 76 }
majik 0:964eb6a2ef00 77
majik 0:964eb6a2ef00 78 #endif