From bbae76efb59d7a173139f49f6cdb632403fd2103 Mon Sep 17 00:00:00 2001 From: Pat Hickey Date: Sun, 13 Nov 2011 14:47:16 +1100 Subject: [PATCH] purple: switch ArduCopter to new sensor objects this uses the new sensor abstractions for the purple/APM1 hardware choice --- ArduCopter/ArduCopter.pde | 53 +++++++++++++++++++++++++++++++++++++-- 1 file changed, 51 insertions(+), 2 deletions(-) diff --git a/ArduCopter/ArduCopter.pde b/ArduCopter/ArduCopter.pde index a81f597945..859aa0efb5 100644 --- a/ArduCopter/ArduCopter.pde +++ b/ArduCopter/ArduCopter.pde @@ -49,16 +49,23 @@ And much more so PLEASE PM me on DIYDRONES to add your contribution to the List // Libraries #include #include +#include #include // ArduPilot Mega RC Library #include // ArduPilot GPS library #include // Arduino I2C lib #include // Arduino SPI lib #include // ArduPilot Mega Flash Memory Library #include // ArduPilot Mega Analog to Digital Converter Library +#include #include // ArduPilot Mega BMP085 Library #include // ArduPilot Mega Magnetometer Library #include // ArduPilot Mega Vector/Matrix math Library +#include // ArduPilot Mega Inertial Sensor (accel & gyro) Library #include // ArduPilot Mega IMU Library +#include // Parent header of Timer and TimerAperiodic + // (only included for makefile libpath to work) +#include // TimerProcess is the scheduler for MPU6000 reads. +#include // TimerAperiodicProcess is the scheduler for ADC reads. #include // ArduPilot Mega DCM Library #include // PI library #include // RC Channel Library @@ -89,6 +96,8 @@ FastSerialPort0(Serial); // FTDI/console FastSerialPort1(Serial1); // GPS port FastSerialPort3(Serial3); // Telemetry port +Arduino_Mega_ISR_Registry isr_registry; + //////////////////////////////////////////////////////////////////////////////// // Parameters //////////////////////////////////////////////////////////////////////////////// @@ -102,6 +111,24 @@ static Parameters g; // prototypes static void update_events(void); +//////////////////////////////////////////////////////////////////////////////// +// RC Hardware +//////////////////////////////////////////////////////////////////////////////// +#if CONFIG_APM_HARDWARE == APM_HARDWARE_PURPLE + APM_RC_Purple APM_RC; +#else + APM_RC_APM1 APM_RC; +#endif + +//////////////////////////////////////////////////////////////////////////////// +// Dataflash +//////////////////////////////////////////////////////////////////////////////// +#if CONFIG_APM_HARDWARE == APM_HARDWARE_PURPLE + DataFlash_Purple DataFlash; +#else + DataFlash_APM1 DataFlash; +#endif + //////////////////////////////////////////////////////////////////////////////// // Sensors @@ -125,7 +152,10 @@ static AP_Int8 *flight_modes = &g.flight_mode1; #if HIL_MODE == HIL_MODE_DISABLED // real sensors + #if CONFIG_ADC == ENABLED AP_ADC_ADS7844 adc; + #endif + APM_BMP085_Class barometer; AP_Compass_HMC5843 compass(Parameters::k_param_compass); @@ -183,7 +213,14 @@ static AP_Int8 *flight_modes = &g.flight_mode1; #if HIL_MODE != HIL_MODE_ATTITUDE #if HIL_MODE != HIL_MODE_SENSORS // Normal - AP_IMU_Oilpan imu(&adc, Parameters::k_param_IMU_calibration); + #if CONFIG_IMU_TYPE == CONFIG_IMU_MPU6000 + AP_InertialSensor_MPU6000 ins( CONFIG_MPU6000_CHIP_SELECT_PIN ); + AP_TimerProcess timer_scheduler; + #else + AP_InertialSensor_Oilpan ins(&adc); + AP_TimerAperiodicProcess timer_scheduler; + #endif + AP_IMU_INS imu(&ins, Parameters::k_param_IMU_calibration); #else // hil imu AP_IMU_Shim imu; @@ -203,12 +240,21 @@ GCS_MAVLINK gcs3(Parameters::k_param_streamrates_port3); //////////////////////////////////////////////////////////////////////////////// // ModeFilter sonar_mode_filter; +#if CONFIG_SONAR == ENABLED + +#if CONFIG_SONAR_SOURCE == SONAR_SOURCE_ADC +AP_AnalogSource_ADC sonar_analog_source( &adc, + CONFIG_SONAR_SOURCE_ADC_CHANNEL, 0.25); +#elif CONFIG_SONAR_SOURCE == SONAR_SOURCE_ANALOG_PIN +AP_AnalogSource_Arduino sonar_analog_source(CONFIG_SONAR_SOURCE_ANALOG_PIN); +#endif #if SONAR_TYPE == MAX_SONAR_XL - AP_RangeFinder_MaxsonarXL sonar(&adc, &sonar_mode_filter);//(SONAR_PORT, &adc); + AP_RangeFinder_MaxsonarXL sonar(&sonar_analog_source, &sonar_mode_filter); #else #error Unrecognised SONAR_TYPE setting. #endif +#endif // agmatthews USERHOOKS //////////////////////////////////////////////////////////////////////////////// @@ -768,9 +814,12 @@ static void fifty_hz_loop() // Read Sonar // ---------- + # if CONFIG_SONAR == ENABLED if(g.sonar_enabled){ sonar_alt = sonar.read(); } + #endif + // agmatthews - USERHOOKS #ifdef USERHOOK_50HZLOOP USERHOOK_50HZLOOP