AP_OpticalFlow: modified to use AP_Semaphore for SPI3 bus when required

This commit is contained in:
rmackay9 2012-10-04 22:46:09 +09:00
parent 23442f9caf
commit f9b16a9a50
2 changed files with 30 additions and 0 deletions

View File

@ -12,6 +12,8 @@
#include "AP_OpticalFlow_ADNS3080.h" #include "AP_OpticalFlow_ADNS3080.h"
#include "SPI.h" #include "SPI.h"
#include "SPI3.h" #include "SPI3.h"
#include "AP_Semaphore.h"
#if defined(ARDUINO) && ARDUINO >= 100 #if defined(ARDUINO) && ARDUINO >= 100
#include "Arduino.h" #include "Arduino.h"
#else #else
@ -179,6 +181,14 @@ AP_OpticalFlow_ADNS3080::read_register(byte address)
uint8_t result = 0; uint8_t result = 0;
uint8_t junk = 0; uint8_t junk = 0;
// get spi3 semaphore if required
if( _spi_bus == ADNS3080_SPIBUS_3 ) {
// if failed to get semaphore then just quietly fail
if( !AP_Semaphore_spi3.get(this) ) {
return 0;
}
}
backup_spi_settings(); backup_spi_settings();
// take the chip select low to select the device // take the chip select low to select the device
@ -199,6 +209,11 @@ AP_OpticalFlow_ADNS3080::read_register(byte address)
restore_spi_settings(); restore_spi_settings();
// get spi3 semaphore if required
if( _spi_bus == ADNS3080_SPIBUS_3 ) {
AP_Semaphore_spi3.release(this);
}
return result; return result;
} }
@ -208,6 +223,15 @@ AP_OpticalFlow_ADNS3080::write_register(byte address, byte value)
{ {
byte junk = 0; byte junk = 0;
// get spi3 semaphore if required
if( _spi_bus == ADNS3080_SPIBUS_3 ) {
// if failed to get semaphore then just quietly fail
if( !AP_Semaphore_spi3.get(this) ) {
Serial.println("Optflow: failed to get spi3 semaphore!");
return;
}
}
backup_spi_settings(); backup_spi_settings();
// take the chip select low to select the device // take the chip select low to select the device
@ -227,6 +251,11 @@ AP_OpticalFlow_ADNS3080::write_register(byte address, byte value)
digitalWrite(_cs_pin, HIGH); digitalWrite(_cs_pin, HIGH);
restore_spi_settings(); restore_spi_settings();
// get spi3 semaphore if required
if( _spi_bus == ADNS3080_SPIBUS_3 ) {
AP_Semaphore_spi3.release(this);
}
} }
// reset sensor by holding a pin high (or is it low?) for 10us. // reset sensor by holding a pin high (or is it low?) for 10us.

View File

@ -10,6 +10,7 @@
#include <SPI3.h> // SPI3 library #include <SPI3.h> // SPI3 library
#include <Arduino_Mega_ISR_Registry.h> #include <Arduino_Mega_ISR_Registry.h>
#include <AP_PeriodicProcess.h> #include <AP_PeriodicProcess.h>
#include <AP_Semaphore.h> // for removing conflict with dataflash on SPI3 bus
#include "AP_OpticalFlow.h" // ArduCopter OpticalFlow Library #include "AP_OpticalFlow.h" // ArduCopter OpticalFlow Library
//////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////