Only imu output

Dependencies:   Servo mbed

Fork of FYDP_Final2 by Mark Vandermeulen

Committer:
tntmarket
Date:
Wed Mar 25 09:58:50 2015 +0000
Revision:
5:d2e955a94940
Parent:
0:21019d94ad33
only imu output

Who changed what in which revision?

UserRevisionLine numberNew contents of line
majik 0:21019d94ad33 1 /* SWSPI, Software SPI library
majik 0:21019d94ad33 2 * Copyright (c) 2012-2014, David R. Van Wagner, http://techwithdave.blogspot.com
majik 0:21019d94ad33 3 *
majik 0:21019d94ad33 4 * Permission is hereby granted, free of charge, to any person obtaining a copy
majik 0:21019d94ad33 5 * of this software and associated documentation files (the "Software"), to deal
majik 0:21019d94ad33 6 * in the Software without restriction, including without limitation the rights
majik 0:21019d94ad33 7 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
majik 0:21019d94ad33 8 * copies of the Software, and to permit persons to whom the Software is
majik 0:21019d94ad33 9 * furnished to do so, subject to the following conditions:
majik 0:21019d94ad33 10 *
majik 0:21019d94ad33 11 * The above copyright notice and this permission notice shall be included in
majik 0:21019d94ad33 12 * all copies or substantial portions of the Software.
majik 0:21019d94ad33 13 *
majik 0:21019d94ad33 14 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
majik 0:21019d94ad33 15 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
majik 0:21019d94ad33 16 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
majik 0:21019d94ad33 17 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
majik 0:21019d94ad33 18 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
majik 0:21019d94ad33 19 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
majik 0:21019d94ad33 20 * THE SOFTWARE.
majik 0:21019d94ad33 21 */
majik 0:21019d94ad33 22
majik 0:21019d94ad33 23 #include <mbed.h>
majik 0:21019d94ad33 24 #include "SWSPI.h"
majik 0:21019d94ad33 25
majik 0:21019d94ad33 26 SWSPI::SWSPI(PinName mosi_pin, PinName miso_pin, PinName sclk_pin)
majik 0:21019d94ad33 27 {
majik 0:21019d94ad33 28 mosi = new DigitalOut(mosi_pin);
majik 0:21019d94ad33 29 miso = new DigitalIn(miso_pin);
majik 0:21019d94ad33 30 sclk = new DigitalOut(sclk_pin);
majik 0:21019d94ad33 31 format(8);
majik 0:21019d94ad33 32 frequency();
majik 0:21019d94ad33 33 }
majik 0:21019d94ad33 34
majik 0:21019d94ad33 35 SWSPI::~SWSPI()
majik 0:21019d94ad33 36 {
majik 0:21019d94ad33 37 delete mosi;
majik 0:21019d94ad33 38 delete miso;
majik 0:21019d94ad33 39 delete sclk;
majik 0:21019d94ad33 40 }
majik 0:21019d94ad33 41
majik 0:21019d94ad33 42 void SWSPI::format(int bits, int mode)
majik 0:21019d94ad33 43 {
majik 0:21019d94ad33 44 this->bits = bits;
majik 0:21019d94ad33 45 this->mode = mode;
majik 0:21019d94ad33 46 polarity = (mode >> 1) & 1;
majik 0:21019d94ad33 47 phase = mode & 1;
majik 0:21019d94ad33 48 sclk->write(polarity);
majik 0:21019d94ad33 49 }
majik 0:21019d94ad33 50
majik 0:21019d94ad33 51 void SWSPI::frequency(int hz)
majik 0:21019d94ad33 52 {
majik 0:21019d94ad33 53 this->freq = hz;
majik 0:21019d94ad33 54 }
majik 0:21019d94ad33 55
majik 0:21019d94ad33 56 int SWSPI::write(int value)
majik 0:21019d94ad33 57 {
majik 0:21019d94ad33 58 int read = 0;
majik 0:21019d94ad33 59 for (int bit = bits-1; bit >= 0; --bit)
majik 0:21019d94ad33 60 {
majik 0:21019d94ad33 61 mosi->write(((value >> bit) & 0x01) != 0);
majik 0:21019d94ad33 62
majik 0:21019d94ad33 63 if (phase == 0)
majik 0:21019d94ad33 64 {
majik 0:21019d94ad33 65 if (miso->read())
majik 0:21019d94ad33 66 read |= (1 << bit);
majik 0:21019d94ad33 67 }
majik 0:21019d94ad33 68
majik 0:21019d94ad33 69 sclk->write(!polarity);
majik 0:21019d94ad33 70
majik 0:21019d94ad33 71 wait(1.0/freq/2);
majik 0:21019d94ad33 72
majik 0:21019d94ad33 73 if (phase == 1)
majik 0:21019d94ad33 74 {
majik 0:21019d94ad33 75 if (miso->read())
majik 0:21019d94ad33 76 read |= (1 << bit);
majik 0:21019d94ad33 77 }
majik 0:21019d94ad33 78
majik 0:21019d94ad33 79 sclk->write(polarity);
majik 0:21019d94ad33 80
majik 0:21019d94ad33 81 wait(1.0/freq/2);
majik 0:21019d94ad33 82 }
majik 0:21019d94ad33 83
majik 0:21019d94ad33 84 return read;
majik 0:21019d94ad33 85 }
majik 0:21019d94ad33 86