2011-01-14 01:38:19 +00:00
|
|
|
/**
|
2012-12-11 23:44:12 -05:00
|
|
|
*****************************************************************************
|
|
|
|
* @file pios_board.c
|
|
|
|
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
|
|
|
|
* @author PhoenixPilot, http://github.com/PhoenixPilot, Copyright (C) 2012
|
2011-01-14 01:38:19 +00:00
|
|
|
* @addtogroup OpenPilotSystem OpenPilot System
|
|
|
|
* @{
|
|
|
|
* @addtogroup OpenPilotCore OpenPilot Core
|
|
|
|
* @{
|
2012-12-11 23:44:12 -05:00
|
|
|
* @brief Defines board specific static initializers for hardware for the CopterControl board.
|
2011-01-14 01:38:19 +00:00
|
|
|
*****************************************************************************/
|
2013-05-19 17:37:30 +03:00
|
|
|
/*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 3 of the License, or
|
2011-01-14 01:38:19 +00:00
|
|
|
* (at your option) any later version.
|
2013-05-19 17:37:30 +03:00
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
|
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
2011-01-14 01:38:19 +00:00
|
|
|
* for more details.
|
2013-05-19 17:37:30 +03:00
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along
|
|
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
2011-01-14 01:38:19 +00:00
|
|
|
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
*/
|
|
|
|
|
2013-04-16 23:03:08 +03:00
|
|
|
#include "inc/openpilot.h"
|
|
|
|
#include <pios_board_info.h>
|
2011-01-14 01:38:19 +00:00
|
|
|
#include <uavobjectsinit.h>
|
bootcfg: use UAVobj to control boot-time HW config
This should mark an end to the compile-time selection of HW
configurations.
Minor changes in board initialization for all platforms:
- Most config structs are marked static to prevent badly written
drivers from directly referring to config data.
- Adapt to changes in .irq fields in config data.
- Adapt to changes in USART IRQ handling.
Major changes in board initialization for CC:
- Use HwSettings UAVObj to decide which drivers to attach to
the "main" port and the flexi port, and select the appropriate
device configuration data.
- HwSettings allows choosing between Disabled, Telemetry, SBUS,
Spektrum,GPS, and I2C for each of the two ports.
- Use ManualControlSettings.InputMode to init/configure the
appropriate receiver module, and register its available rx channels
with the PIOS_RCVR layer. Can choose between PWM, Spektrum and PPM
at board init time. PPM driver is broken, and SBUS will work once
it is added to this UAVObj as an option.
- CC build now includes code for SBUS, Spektrum and PWM receivers in
every firmware image.
PIOS_USART driver:
- Now handles its own low-level IRQs internally
- If NULL upper-level IRQ handler is bound in at board init time
then rx/tx is satisfied by internal PIOS_USART buffered IO routines
which are (typically) attached to the COM layer.
- If an alternate upper-level IRQ handler is bound in at board init
then that handler is called and expected to clear down the USART
IRQ sources. This is used by Spektrum and SBUS drivers.
PIOS_SBUS and PIOS_SPEKTRUM drivers:
- Improved data/API hiding
- No longer assume they know where their config data is stored which
allows for boot-time alternate configurations for the driver.
- Now registers an upper-level IRQ handlerwith the USART layer to
decouple the driver from which USART it is actually attached to.
2011-07-05 20:21:00 -04:00
|
|
|
#include <hwsettings.h>
|
|
|
|
#include <manualcontrolsettings.h>
|
2011-08-27 15:57:09 -05:00
|
|
|
#include <gcsreceiver.h>
|
2013-05-03 07:01:14 +09:30
|
|
|
#include <taskinfo.h>
|
2015-02-09 00:51:46 +01:00
|
|
|
#include <sanitycheck.h>
|
|
|
|
#include <actuatorsettings.h>
|
2011-01-14 01:38:19 +00:00
|
|
|
|
2014-06-07 00:47:06 +02:00
|
|
|
#ifdef PIOS_INCLUDE_INSTRUMENTATION
|
|
|
|
#include <pios_instrumentation.h>
|
|
|
|
#endif
|
2015-01-11 17:09:11 +01:00
|
|
|
#if defined(PIOS_INCLUDE_ADXL345)
|
|
|
|
#include <pios_adxl345.h>
|
|
|
|
#endif
|
|
|
|
|
2013-04-16 23:03:08 +03:00
|
|
|
/*
|
|
|
|
* Pull in the board-specific static HW definitions.
|
|
|
|
* Including .c files is a bit ugly but this allows all of
|
|
|
|
* the HW definitions to be const and static to limit their
|
|
|
|
* scope.
|
|
|
|
*
|
|
|
|
* NOTE: THIS IS THE ONLY PLACE THAT SHOULD EVER INCLUDE THIS FILE
|
|
|
|
*/
|
|
|
|
#include "../board_hw_defs.c"
|
2011-01-14 01:38:19 +00:00
|
|
|
|
2012-01-22 19:41:41 -05:00
|
|
|
/* One slot per selectable receiver group.
|
|
|
|
* eg. PWM, PPM, GCS, DSMMAINPORT, DSMFLEXIPORT, SBUS
|
|
|
|
* NOTE: No slot in this map for NONE.
|
2011-06-13 03:04:49 +03:00
|
|
|
*/
|
2012-01-22 19:41:41 -05:00
|
|
|
uint32_t pios_rcvr_group_map[MANUALCONTROLSETTINGS_CHANNELGROUPS_NONE];
|
2011-01-14 01:38:19 +00:00
|
|
|
|
2015-02-09 00:51:46 +01:00
|
|
|
static SystemAlarmsExtendedAlarmStatusOptions CopterControlConfigHook();
|
2015-02-11 23:59:23 +01:00
|
|
|
static void ActuatorSettingsUpdatedCb(UAVObjEvent *ev);
|
2015-02-09 00:51:46 +01:00
|
|
|
|
2013-05-19 17:37:30 +03:00
|
|
|
#define PIOS_COM_TELEM_RF_RX_BUF_LEN 32
|
|
|
|
#define PIOS_COM_TELEM_RF_TX_BUF_LEN 12
|
2011-07-29 10:04:55 -04:00
|
|
|
|
2013-05-19 17:37:30 +03:00
|
|
|
#define PIOS_COM_GPS_RX_BUF_LEN 32
|
2011-07-29 10:04:55 -04:00
|
|
|
|
2013-05-19 17:37:30 +03:00
|
|
|
#define PIOS_COM_TELEM_USB_RX_BUF_LEN 65
|
|
|
|
#define PIOS_COM_TELEM_USB_TX_BUF_LEN 65
|
2011-07-29 10:04:55 -04:00
|
|
|
|
2013-05-19 17:37:30 +03:00
|
|
|
#define PIOS_COM_BRIDGE_RX_BUF_LEN 65
|
|
|
|
#define PIOS_COM_BRIDGE_TX_BUF_LEN 12
|
2011-12-21 21:04:29 -05:00
|
|
|
|
2013-05-19 17:37:30 +03:00
|
|
|
#define PIOS_COM_HKOSD_TX_BUF_LEN 22
|
2013-03-28 18:20:50 +02:00
|
|
|
|
2012-10-11 00:06:28 -04:00
|
|
|
#if defined(PIOS_INCLUDE_DEBUG_CONSOLE)
|
|
|
|
#define PIOS_COM_DEBUGCONSOLE_TX_BUF_LEN 40
|
|
|
|
uint32_t pios_com_debug_id;
|
2013-05-19 17:37:30 +03:00
|
|
|
#endif /* PIOS_INCLUDE_DEBUG_CONSOLE */
|
2012-10-11 00:06:28 -04:00
|
|
|
|
2011-02-12 22:19:43 +00:00
|
|
|
uint32_t pios_com_telem_rf_id;
|
2011-09-14 17:04:15 -04:00
|
|
|
uint32_t pios_com_telem_usb_id;
|
2011-12-30 13:07:25 -05:00
|
|
|
uint32_t pios_com_vcp_id;
|
2011-02-12 22:19:43 +00:00
|
|
|
uint32_t pios_com_gps_id;
|
2011-12-30 13:07:25 -05:00
|
|
|
uint32_t pios_com_bridge_id;
|
2013-03-28 18:20:50 +02:00
|
|
|
uint32_t pios_com_hkosd_id;
|
2011-02-12 22:19:43 +00:00
|
|
|
|
2012-08-05 21:45:27 -04:00
|
|
|
uint32_t pios_usb_rctx_id;
|
|
|
|
|
2013-05-11 17:15:07 +02:00
|
|
|
uintptr_t pios_uavo_settings_fs_id;
|
2013-06-09 19:20:00 +02:00
|
|
|
uintptr_t pios_user_fs_id = 0;
|
2012-01-23 23:45:40 -06:00
|
|
|
/**
|
2012-03-26 00:22:59 -05:00
|
|
|
* Configuration for MPU6000 chip
|
2012-01-23 23:45:40 -06:00
|
|
|
*/
|
2012-03-26 00:22:59 -05:00
|
|
|
#if defined(PIOS_INCLUDE_MPU6000)
|
|
|
|
#include "pios_mpu6000.h"
|
2013-03-03 20:05:27 +01:00
|
|
|
#include "pios_mpu6000_config.h"
|
2012-03-26 00:22:59 -05:00
|
|
|
static const struct pios_exti_cfg pios_exti_mpu6000_cfg __exti_config = {
|
2013-05-19 17:37:30 +03:00
|
|
|
.vector = PIOS_MPU6000_IRQHandler,
|
|
|
|
.line = EXTI_Line3,
|
|
|
|
.pin = {
|
|
|
|
.gpio = GPIOA,
|
|
|
|
.init = {
|
|
|
|
.GPIO_Pin = GPIO_Pin_3,
|
|
|
|
.GPIO_Speed = GPIO_Speed_10MHz,
|
|
|
|
.GPIO_Mode = GPIO_Mode_IN_FLOATING,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
.irq = {
|
|
|
|
.init = {
|
|
|
|
.NVIC_IRQChannel = EXTI3_IRQn,
|
|
|
|
.NVIC_IRQChannelPreemptionPriority = PIOS_IRQ_PRIO_HIGH,
|
|
|
|
.NVIC_IRQChannelSubPriority = 0,
|
|
|
|
.NVIC_IRQChannelCmd = ENABLE,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
.exti = {
|
|
|
|
.init = {
|
|
|
|
.EXTI_Line = EXTI_Line3, // matches above GPIO pin
|
|
|
|
.EXTI_Mode = EXTI_Mode_Interrupt,
|
|
|
|
.EXTI_Trigger = EXTI_Trigger_Rising,
|
|
|
|
.EXTI_LineCmd = ENABLE,
|
|
|
|
},
|
|
|
|
},
|
2012-01-23 23:29:17 -06:00
|
|
|
};
|
|
|
|
|
2012-03-26 00:22:59 -05:00
|
|
|
static const struct pios_mpu6000_cfg pios_mpu6000_cfg = {
|
2013-05-19 17:37:30 +03:00
|
|
|
.exti_cfg = &pios_exti_mpu6000_cfg,
|
|
|
|
.Fifo_store = PIOS_MPU6000_FIFO_TEMP_OUT | PIOS_MPU6000_FIFO_GYRO_X_OUT | PIOS_MPU6000_FIFO_GYRO_Y_OUT | PIOS_MPU6000_FIFO_GYRO_Z_OUT,
|
2014-10-07 11:40:39 +02:00
|
|
|
// Clock at 8 khz, downsampled by 8 for 1000 Hz
|
2014-10-10 01:21:40 +02:00
|
|
|
.Smpl_rate_div_no_dlp = 7,
|
2014-10-11 23:54:21 +02:00
|
|
|
// Clock at 1 khz, downsampled by 1 for 1000 Hz
|
2014-10-10 01:21:40 +02:00
|
|
|
.Smpl_rate_div_dlp = 0,
|
2014-10-07 11:40:39 +02:00
|
|
|
.interrupt_cfg = PIOS_MPU6000_INT_CLR_ANYRD,
|
|
|
|
.interrupt_en = PIOS_MPU6000_INTEN_DATA_RDY,
|
2014-10-10 01:21:40 +02:00
|
|
|
.User_ctl = PIOS_MPU6000_USERCTL_DIS_I2C,
|
2014-10-07 11:40:39 +02:00
|
|
|
.Pwr_mgmt_clk = PIOS_MPU6000_PWRMGMT_PLL_X_CLK,
|
|
|
|
.accel_range = PIOS_MPU6000_ACCEL_8G,
|
|
|
|
.gyro_range = PIOS_MPU6000_SCALE_2000_DEG,
|
2013-05-19 17:37:30 +03:00
|
|
|
.filter = PIOS_MPU6000_LOWPASS_256_HZ,
|
2014-10-07 11:40:39 +02:00
|
|
|
.orientation = PIOS_MPU6000_TOP_180DEG,
|
2014-10-10 01:21:40 +02:00
|
|
|
.fast_prescaler = PIOS_SPI_PRESCALER_4,
|
|
|
|
.std_prescaler = PIOS_SPI_PRESCALER_64,
|
|
|
|
.max_downsample = 2
|
2012-01-20 14:14:57 -06:00
|
|
|
};
|
2012-03-26 00:22:59 -05:00
|
|
|
#endif /* PIOS_INCLUDE_MPU6000 */
|
2012-01-20 14:14:57 -06:00
|
|
|
|
2011-02-12 22:19:43 +00:00
|
|
|
/**
|
|
|
|
* PIOS_Board_Init()
|
|
|
|
* initializes all the core subsystems on this specific hardware
|
|
|
|
* called from System/openpilot.c
|
|
|
|
*/
|
2012-03-26 00:22:59 -05:00
|
|
|
int32_t init_test;
|
2013-05-19 17:37:30 +03:00
|
|
|
void PIOS_Board_Init(void)
|
|
|
|
{
|
|
|
|
/* Delay system */
|
|
|
|
PIOS_DELAY_Init();
|
2011-02-12 22:19:43 +00:00
|
|
|
|
2013-05-19 17:37:30 +03:00
|
|
|
const struct pios_board_info *bdinfo = &pios_board_info_blob;
|
bootcfg: use UAVobj to control boot-time HW config
This should mark an end to the compile-time selection of HW
configurations.
Minor changes in board initialization for all platforms:
- Most config structs are marked static to prevent badly written
drivers from directly referring to config data.
- Adapt to changes in .irq fields in config data.
- Adapt to changes in USART IRQ handling.
Major changes in board initialization for CC:
- Use HwSettings UAVObj to decide which drivers to attach to
the "main" port and the flexi port, and select the appropriate
device configuration data.
- HwSettings allows choosing between Disabled, Telemetry, SBUS,
Spektrum,GPS, and I2C for each of the two ports.
- Use ManualControlSettings.InputMode to init/configure the
appropriate receiver module, and register its available rx channels
with the PIOS_RCVR layer. Can choose between PWM, Spektrum and PPM
at board init time. PPM driver is broken, and SBUS will work once
it is added to this UAVObj as an option.
- CC build now includes code for SBUS, Spektrum and PWM receivers in
every firmware image.
PIOS_USART driver:
- Now handles its own low-level IRQs internally
- If NULL upper-level IRQ handler is bound in at board init time
then rx/tx is satisfied by internal PIOS_USART buffered IO routines
which are (typically) attached to the COM layer.
- If an alternate upper-level IRQ handler is bound in at board init
then that handler is called and expected to clear down the USART
IRQ sources. This is used by Spektrum and SBUS drivers.
PIOS_SBUS and PIOS_SPEKTRUM drivers:
- Improved data/API hiding
- No longer assume they know where their config data is stored which
allows for boot-time alternate configurations for the driver.
- Now registers an upper-level IRQ handlerwith the USART layer to
decouple the driver from which USART it is actually attached to.
2011-07-05 20:21:00 -04:00
|
|
|
|
2012-01-24 14:37:04 -06:00
|
|
|
#if defined(PIOS_INCLUDE_LED)
|
2013-07-16 21:09:48 -07:00
|
|
|
const struct pios_gpio_cfg *led_cfg = PIOS_BOARD_HW_DEFS_GetLedCfg(bdinfo->board_rev);
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_Assert(led_cfg);
|
|
|
|
PIOS_LED_Init(led_cfg);
|
|
|
|
#endif /* PIOS_INCLUDE_LED */
|
2012-01-24 14:37:04 -06:00
|
|
|
|
2014-06-07 00:47:06 +02:00
|
|
|
#ifdef PIOS_INCLUDE_INSTRUMENTATION
|
|
|
|
PIOS_Instrumentation_Init(PIOS_INSTRUMENTATION_MAX_COUNTERS);
|
|
|
|
#endif
|
|
|
|
|
2012-01-24 10:32:42 -06:00
|
|
|
#if defined(PIOS_INCLUDE_SPI)
|
2013-05-19 17:37:30 +03:00
|
|
|
/* Set up the SPI interface to the serial flash */
|
|
|
|
|
|
|
|
switch (bdinfo->board_rev) {
|
|
|
|
case BOARD_REVISION_CC:
|
|
|
|
if (PIOS_SPI_Init(&pios_spi_flash_accel_id, &pios_spi_flash_accel_cfg_cc)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case BOARD_REVISION_CC3D:
|
|
|
|
if (PIOS_SPI_Init(&pios_spi_flash_accel_id, &pios_spi_flash_accel_cfg_cc3d)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
2012-01-24 16:21:34 -06:00
|
|
|
|
2012-01-24 10:32:42 -06:00
|
|
|
#endif
|
2011-02-12 22:19:43 +00:00
|
|
|
|
2013-05-19 17:37:30 +03:00
|
|
|
uintptr_t flash_id;
|
|
|
|
switch (bdinfo->board_rev) {
|
|
|
|
case BOARD_REVISION_CC:
|
|
|
|
if (PIOS_Flash_Jedec_Init(&flash_id, pios_spi_flash_accel_id, 1)) {
|
|
|
|
PIOS_DEBUG_Assert(0);
|
|
|
|
}
|
|
|
|
if (PIOS_FLASHFS_Logfs_Init(&pios_uavo_settings_fs_id, &flashfs_w25x_cfg, &pios_jedec_flash_driver, flash_id)) {
|
|
|
|
PIOS_DEBUG_Assert(0);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case BOARD_REVISION_CC3D:
|
|
|
|
if (PIOS_Flash_Jedec_Init(&flash_id, pios_spi_flash_accel_id, 0)) {
|
|
|
|
PIOS_DEBUG_Assert(0);
|
|
|
|
}
|
|
|
|
if (PIOS_FLASHFS_Logfs_Init(&pios_uavo_settings_fs_id, &flashfs_m25p_cfg, &pios_jedec_flash_driver, flash_id)) {
|
|
|
|
PIOS_DEBUG_Assert(0);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
PIOS_DEBUG_Assert(0);
|
|
|
|
}
|
|
|
|
|
2013-06-09 20:16:40 -07:00
|
|
|
/* Initialize the task monitor */
|
|
|
|
if (PIOS_TASK_MONITOR_Initialize(TASKINFO_RUNNING_NUMELEM)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
|
2013-06-27 12:25:39 +02:00
|
|
|
/* Initialize the delayed callback library */
|
2014-02-02 22:08:16 +01:00
|
|
|
PIOS_CALLBACKSCHEDULER_Initialize();
|
2013-06-27 12:25:39 +02:00
|
|
|
|
2013-05-19 17:37:30 +03:00
|
|
|
/* Initialize UAVObject libraries */
|
|
|
|
EventDispatcherInitialize();
|
|
|
|
UAVObjInitialize();
|
2011-02-12 22:19:43 +00:00
|
|
|
|
2012-01-22 18:22:59 -05:00
|
|
|
#if defined(PIOS_INCLUDE_RTC)
|
2013-05-19 17:37:30 +03:00
|
|
|
/* Initialize the real-time clock and its associated tick */
|
|
|
|
PIOS_RTC_Init(&pios_rtc_main_cfg);
|
2012-01-22 18:22:59 -05:00
|
|
|
#endif
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_IAP_Init();
|
|
|
|
// check for safe mode commands from gcs
|
|
|
|
if (PIOS_IAP_ReadBootCmd(0) == PIOS_IAP_CLEAR_FLASH_CMD_0 &&
|
|
|
|
PIOS_IAP_ReadBootCmd(1) == PIOS_IAP_CLEAR_FLASH_CMD_1 &&
|
|
|
|
PIOS_IAP_ReadBootCmd(2) == PIOS_IAP_CLEAR_FLASH_CMD_2) {
|
|
|
|
PIOS_FLASHFS_Format(pios_uavo_settings_fs_id);
|
|
|
|
PIOS_IAP_WriteBootCmd(0, 0);
|
|
|
|
PIOS_IAP_WriteBootCmd(1, 0);
|
|
|
|
PIOS_IAP_WriteBootCmd(2, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
HwSettingsInitialize();
|
2011-12-30 13:26:54 -05:00
|
|
|
|
|
|
|
#ifndef ERASE_FLASH
|
2015-02-24 22:02:25 +01:00
|
|
|
#ifdef PIOS_INCLUDE_WDG
|
2013-05-19 17:37:30 +03:00
|
|
|
/* Initialize watchdog as early as possible to catch faults during init */
|
|
|
|
PIOS_WDG_Init();
|
2015-02-24 22:02:25 +01:00
|
|
|
#endif
|
2011-07-02 19:25:35 -04:00
|
|
|
#endif
|
|
|
|
|
2013-05-19 17:37:30 +03:00
|
|
|
/* Initialize the alarms library */
|
|
|
|
AlarmsInitialize();
|
|
|
|
|
|
|
|
/* Check for repeated boot failures */
|
|
|
|
uint16_t boot_count = PIOS_IAP_ReadBootCount();
|
|
|
|
if (boot_count < 3) {
|
|
|
|
PIOS_IAP_WriteBootCount(++boot_count);
|
|
|
|
AlarmsClear(SYSTEMALARMS_ALARM_BOOTFAULT);
|
|
|
|
} else {
|
|
|
|
/* Too many failed boot attempts, force hwsettings to defaults */
|
|
|
|
HwSettingsSetDefaults(HwSettingsHandle(), 0);
|
|
|
|
AlarmsSet(SYSTEMALARMS_ALARM_BOOTFAULT, SYSTEMALARMS_ALARM_CRITICAL);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Set up pulse timers */
|
|
|
|
PIOS_TIM_InitClock(&tim_1_cfg);
|
|
|
|
PIOS_TIM_InitClock(&tim_2_cfg);
|
|
|
|
PIOS_TIM_InitClock(&tim_3_cfg);
|
|
|
|
PIOS_TIM_InitClock(&tim_4_cfg);
|
2011-08-12 23:23:16 -04:00
|
|
|
|
2012-01-02 14:03:15 -05:00
|
|
|
#if defined(PIOS_INCLUDE_USB)
|
2013-05-19 17:37:30 +03:00
|
|
|
/* Initialize board specific USB data */
|
|
|
|
PIOS_USB_BOARD_DATA_Init();
|
2012-01-14 14:17:06 -05:00
|
|
|
|
2012-05-09 22:27:52 -04:00
|
|
|
|
2013-05-19 17:37:30 +03:00
|
|
|
/* Flags to determine if various USB interfaces are advertised */
|
|
|
|
bool usb_hid_present = false;
|
|
|
|
bool usb_cdc_present = false;
|
2012-01-14 14:17:06 -05:00
|
|
|
|
2012-05-09 22:27:52 -04:00
|
|
|
#if defined(PIOS_INCLUDE_USB_CDC)
|
2013-05-19 17:37:30 +03:00
|
|
|
if (PIOS_USB_DESC_HID_CDC_Init()) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
usb_hid_present = true;
|
|
|
|
usb_cdc_present = true;
|
2012-05-09 22:27:52 -04:00
|
|
|
#else
|
2013-05-19 17:37:30 +03:00
|
|
|
if (PIOS_USB_DESC_HID_ONLY_Init()) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
usb_hid_present = true;
|
2012-05-09 22:27:52 -04:00
|
|
|
#endif
|
2012-01-14 14:17:06 -05:00
|
|
|
|
2013-05-19 17:37:30 +03:00
|
|
|
uint32_t pios_usb_id;
|
|
|
|
|
|
|
|
switch (bdinfo->board_rev) {
|
|
|
|
case BOARD_REVISION_CC:
|
|
|
|
PIOS_USB_Init(&pios_usb_id, &pios_usb_main_cfg_cc);
|
|
|
|
break;
|
|
|
|
case BOARD_REVISION_CC3D:
|
|
|
|
PIOS_USB_Init(&pios_usb_id, &pios_usb_main_cfg_cc3d);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
2011-12-21 21:04:29 -05:00
|
|
|
|
2012-01-02 14:03:15 -05:00
|
|
|
#if defined(PIOS_INCLUDE_USB_CDC)
|
2012-01-14 14:17:06 -05:00
|
|
|
|
2013-05-19 17:37:30 +03:00
|
|
|
uint8_t hwsettings_usb_vcpport;
|
|
|
|
/* Configure the USB VCP port */
|
|
|
|
HwSettingsUSB_VCPPortGet(&hwsettings_usb_vcpport);
|
2011-12-21 21:04:29 -05:00
|
|
|
|
2013-05-19 17:37:30 +03:00
|
|
|
if (!usb_cdc_present) {
|
|
|
|
/* Force VCP port function to disabled if we haven't advertised VCP in our USB descriptor */
|
|
|
|
hwsettings_usb_vcpport = HWSETTINGS_USB_VCPPORT_DISABLED;
|
|
|
|
}
|
2012-01-14 14:17:06 -05:00
|
|
|
|
2013-05-19 17:37:30 +03:00
|
|
|
switch (hwsettings_usb_vcpport) {
|
|
|
|
case HWSETTINGS_USB_VCPPORT_DISABLED:
|
|
|
|
break;
|
|
|
|
case HWSETTINGS_USB_VCPPORT_USBTELEMETRY:
|
2011-12-21 21:04:29 -05:00
|
|
|
#if defined(PIOS_INCLUDE_COM)
|
2013-05-19 17:37:30 +03:00
|
|
|
{
|
|
|
|
uint32_t pios_usb_cdc_id;
|
|
|
|
if (PIOS_USB_CDC_Init(&pios_usb_cdc_id, &pios_usb_cdc_cfg, pios_usb_id)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
2014-06-11 20:11:48 +02:00
|
|
|
uint8_t *rx_buffer = (uint8_t *)pios_malloc(PIOS_COM_TELEM_USB_RX_BUF_LEN);
|
|
|
|
uint8_t *tx_buffer = (uint8_t *)pios_malloc(PIOS_COM_TELEM_USB_TX_BUF_LEN);
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_Assert(rx_buffer);
|
|
|
|
PIOS_Assert(tx_buffer);
|
|
|
|
if (PIOS_COM_Init(&pios_com_telem_usb_id, &pios_usb_cdc_com_driver, pios_usb_cdc_id,
|
|
|
|
rx_buffer, PIOS_COM_TELEM_USB_RX_BUF_LEN,
|
|
|
|
tx_buffer, PIOS_COM_TELEM_USB_TX_BUF_LEN)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif /* PIOS_INCLUDE_COM */
|
|
|
|
break;
|
|
|
|
case HWSETTINGS_USB_VCPPORT_COMBRIDGE:
|
2012-01-02 14:03:15 -05:00
|
|
|
#if defined(PIOS_INCLUDE_COM)
|
2013-05-19 17:37:30 +03:00
|
|
|
{
|
|
|
|
uint32_t pios_usb_cdc_id;
|
|
|
|
if (PIOS_USB_CDC_Init(&pios_usb_cdc_id, &pios_usb_cdc_cfg, pios_usb_id)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
2014-06-11 20:11:48 +02:00
|
|
|
uint8_t *rx_buffer = (uint8_t *)pios_malloc(PIOS_COM_BRIDGE_RX_BUF_LEN);
|
|
|
|
uint8_t *tx_buffer = (uint8_t *)pios_malloc(PIOS_COM_BRIDGE_TX_BUF_LEN);
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_Assert(rx_buffer);
|
|
|
|
PIOS_Assert(tx_buffer);
|
|
|
|
if (PIOS_COM_Init(&pios_com_vcp_id, &pios_usb_cdc_com_driver, pios_usb_cdc_id,
|
|
|
|
rx_buffer, PIOS_COM_BRIDGE_RX_BUF_LEN,
|
|
|
|
tx_buffer, PIOS_COM_BRIDGE_TX_BUF_LEN)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif /* PIOS_INCLUDE_COM */
|
|
|
|
break;
|
|
|
|
case HWSETTINGS_USB_VCPPORT_DEBUGCONSOLE:
|
2012-10-11 00:51:09 -04:00
|
|
|
#if defined(PIOS_INCLUDE_COM)
|
|
|
|
#if defined(PIOS_INCLUDE_DEBUG_CONSOLE)
|
2013-05-19 17:37:30 +03:00
|
|
|
{
|
|
|
|
uint32_t pios_usb_cdc_id;
|
|
|
|
if (PIOS_USB_CDC_Init(&pios_usb_cdc_id, &pios_usb_cdc_cfg, pios_usb_id)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
2014-06-11 20:11:48 +02:00
|
|
|
uint8_t *tx_buffer = (uint8_t *)pios_malloc(PIOS_COM_DEBUGCONSOLE_TX_BUF_LEN);
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_Assert(tx_buffer);
|
|
|
|
if (PIOS_COM_Init(&pios_com_debug_id, &pios_usb_cdc_com_driver, pios_usb_cdc_id,
|
|
|
|
NULL, 0,
|
|
|
|
tx_buffer, PIOS_COM_DEBUGCONSOLE_TX_BUF_LEN)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif /* PIOS_INCLUDE_DEBUG_CONSOLE */
|
|
|
|
#endif /* PIOS_INCLUDE_COM */
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
#endif /* PIOS_INCLUDE_USB_CDC */
|
2011-12-28 16:16:29 -05:00
|
|
|
|
2012-01-02 14:03:15 -05:00
|
|
|
#if defined(PIOS_INCLUDE_USB_HID)
|
2013-05-19 17:37:30 +03:00
|
|
|
/* Configure the usb HID port */
|
|
|
|
uint8_t hwsettings_usb_hidport;
|
|
|
|
HwSettingsUSB_HIDPortGet(&hwsettings_usb_hidport);
|
|
|
|
|
|
|
|
if (!usb_hid_present) {
|
|
|
|
/* Force HID port function to disabled if we haven't advertised HID in our USB descriptor */
|
|
|
|
hwsettings_usb_hidport = HWSETTINGS_USB_HIDPORT_DISABLED;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (hwsettings_usb_hidport) {
|
|
|
|
case HWSETTINGS_USB_HIDPORT_DISABLED:
|
|
|
|
break;
|
|
|
|
case HWSETTINGS_USB_HIDPORT_USBTELEMETRY:
|
2011-12-21 21:04:29 -05:00
|
|
|
#if defined(PIOS_INCLUDE_COM)
|
2013-05-19 17:37:30 +03:00
|
|
|
{
|
|
|
|
uint32_t pios_usb_hid_id;
|
|
|
|
if (PIOS_USB_HID_Init(&pios_usb_hid_id, &pios_usb_hid_cfg, pios_usb_id)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
2014-06-11 20:11:48 +02:00
|
|
|
uint8_t *rx_buffer = (uint8_t *)pios_malloc(PIOS_COM_TELEM_USB_RX_BUF_LEN);
|
|
|
|
uint8_t *tx_buffer = (uint8_t *)pios_malloc(PIOS_COM_TELEM_USB_TX_BUF_LEN);
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_Assert(rx_buffer);
|
|
|
|
PIOS_Assert(tx_buffer);
|
|
|
|
if (PIOS_COM_Init(&pios_com_telem_usb_id, &pios_usb_hid_com_driver, pios_usb_hid_id,
|
|
|
|
rx_buffer, PIOS_COM_TELEM_USB_RX_BUF_LEN,
|
|
|
|
tx_buffer, PIOS_COM_TELEM_USB_TX_BUF_LEN)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif /* PIOS_INCLUDE_COM */
|
|
|
|
break;
|
|
|
|
case HWSETTINGS_USB_HIDPORT_RCTRANSMITTER:
|
2012-08-05 21:45:27 -04:00
|
|
|
#if defined(PIOS_INCLUDE_USB_RCTX)
|
2013-05-19 17:37:30 +03:00
|
|
|
{
|
|
|
|
if (PIOS_USB_RCTX_Init(&pios_usb_rctx_id, &pios_usb_rctx_cfg, pios_usb_id)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif /* PIOS_INCLUDE_USB_RCTX */
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* PIOS_INCLUDE_USB_HID */
|
|
|
|
|
|
|
|
#endif /* PIOS_INCLUDE_USB */
|
|
|
|
|
|
|
|
/* Configure the main IO port */
|
|
|
|
uint8_t hwsettings_DSMxBind;
|
|
|
|
HwSettingsDSMxBindGet(&hwsettings_DSMxBind);
|
|
|
|
uint8_t hwsettings_cc_mainport;
|
|
|
|
HwSettingsCC_MainPortGet(&hwsettings_cc_mainport);
|
|
|
|
|
|
|
|
switch (hwsettings_cc_mainport) {
|
|
|
|
case HWSETTINGS_CC_MAINPORT_DISABLED:
|
|
|
|
break;
|
|
|
|
case HWSETTINGS_CC_MAINPORT_TELEMETRY:
|
2011-06-16 15:06:01 +03:00
|
|
|
#if defined(PIOS_INCLUDE_TELEMETRY_RF)
|
2013-05-19 17:37:30 +03:00
|
|
|
{
|
|
|
|
uint32_t pios_usart_generic_id;
|
|
|
|
if (PIOS_USART_Init(&pios_usart_generic_id, &pios_usart_generic_main_cfg)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
|
2014-06-11 20:11:48 +02:00
|
|
|
uint8_t *rx_buffer = (uint8_t *)pios_malloc(PIOS_COM_TELEM_RF_RX_BUF_LEN);
|
|
|
|
uint8_t *tx_buffer = (uint8_t *)pios_malloc(PIOS_COM_TELEM_RF_TX_BUF_LEN);
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_Assert(rx_buffer);
|
|
|
|
PIOS_Assert(tx_buffer);
|
|
|
|
if (PIOS_COM_Init(&pios_com_telem_rf_id, &pios_usart_com_driver, pios_usart_generic_id,
|
|
|
|
rx_buffer, PIOS_COM_TELEM_RF_RX_BUF_LEN,
|
|
|
|
tx_buffer, PIOS_COM_TELEM_RF_TX_BUF_LEN)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif /* PIOS_INCLUDE_TELEMETRY_RF */
|
|
|
|
break;
|
|
|
|
case HWSETTINGS_CC_MAINPORT_SBUS:
|
bootcfg: use UAVobj to control boot-time HW config
This should mark an end to the compile-time selection of HW
configurations.
Minor changes in board initialization for all platforms:
- Most config structs are marked static to prevent badly written
drivers from directly referring to config data.
- Adapt to changes in .irq fields in config data.
- Adapt to changes in USART IRQ handling.
Major changes in board initialization for CC:
- Use HwSettings UAVObj to decide which drivers to attach to
the "main" port and the flexi port, and select the appropriate
device configuration data.
- HwSettings allows choosing between Disabled, Telemetry, SBUS,
Spektrum,GPS, and I2C for each of the two ports.
- Use ManualControlSettings.InputMode to init/configure the
appropriate receiver module, and register its available rx channels
with the PIOS_RCVR layer. Can choose between PWM, Spektrum and PPM
at board init time. PPM driver is broken, and SBUS will work once
it is added to this UAVObj as an option.
- CC build now includes code for SBUS, Spektrum and PWM receivers in
every firmware image.
PIOS_USART driver:
- Now handles its own low-level IRQs internally
- If NULL upper-level IRQ handler is bound in at board init time
then rx/tx is satisfied by internal PIOS_USART buffered IO routines
which are (typically) attached to the COM layer.
- If an alternate upper-level IRQ handler is bound in at board init
then that handler is called and expected to clear down the USART
IRQ sources. This is used by Spektrum and SBUS drivers.
PIOS_SBUS and PIOS_SPEKTRUM drivers:
- Improved data/API hiding
- No longer assume they know where their config data is stored which
allows for boot-time alternate configurations for the driver.
- Now registers an upper-level IRQ handlerwith the USART layer to
decouple the driver from which USART it is actually attached to.
2011-07-05 20:21:00 -04:00
|
|
|
#if defined(PIOS_INCLUDE_SBUS)
|
2013-05-19 17:37:30 +03:00
|
|
|
{
|
|
|
|
uint32_t pios_usart_sbus_id;
|
|
|
|
if (PIOS_USART_Init(&pios_usart_sbus_id, &pios_usart_sbus_main_cfg)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t pios_sbus_id;
|
|
|
|
if (PIOS_SBus_Init(&pios_sbus_id, &pios_sbus_cfg, &pios_usart_com_driver, pios_usart_sbus_id)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t pios_sbus_rcvr_id;
|
|
|
|
if (PIOS_RCVR_Init(&pios_sbus_rcvr_id, &pios_sbus_rcvr_driver, pios_sbus_id)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
pios_rcvr_group_map[MANUALCONTROLSETTINGS_CHANNELGROUPS_SBUS] = pios_sbus_rcvr_id;
|
|
|
|
}
|
|
|
|
#endif /* PIOS_INCLUDE_SBUS */
|
|
|
|
break;
|
|
|
|
case HWSETTINGS_CC_MAINPORT_GPS:
|
2011-02-12 22:19:43 +00:00
|
|
|
#if defined(PIOS_INCLUDE_GPS)
|
2013-05-19 17:37:30 +03:00
|
|
|
{
|
|
|
|
uint32_t pios_usart_generic_id;
|
|
|
|
if (PIOS_USART_Init(&pios_usart_generic_id, &pios_usart_generic_main_cfg)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
|
2014-06-11 20:11:48 +02:00
|
|
|
uint8_t *rx_buffer = (uint8_t *)pios_malloc(PIOS_COM_GPS_RX_BUF_LEN);
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_Assert(rx_buffer);
|
|
|
|
if (PIOS_COM_Init(&pios_com_gps_id, &pios_usart_com_driver, pios_usart_generic_id,
|
|
|
|
rx_buffer, PIOS_COM_GPS_RX_BUF_LEN,
|
|
|
|
NULL, 0)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif /* PIOS_INCLUDE_GPS */
|
|
|
|
break;
|
2014-11-22 08:32:00 +11:00
|
|
|
case HWSETTINGS_CC_MAINPORT_DSM:
|
2011-11-04 21:40:34 +02:00
|
|
|
#if defined(PIOS_INCLUDE_DSM)
|
2013-05-19 17:37:30 +03:00
|
|
|
{
|
|
|
|
uint32_t pios_usart_dsm_id;
|
|
|
|
if (PIOS_USART_Init(&pios_usart_dsm_id, &pios_usart_dsm_main_cfg)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t pios_dsm_id;
|
|
|
|
if (PIOS_DSM_Init(&pios_dsm_id,
|
|
|
|
&pios_dsm_main_cfg,
|
|
|
|
&pios_usart_com_driver,
|
|
|
|
pios_usart_dsm_id,
|
2014-11-22 08:32:00 +11:00
|
|
|
0)) {
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t pios_dsm_rcvr_id;
|
|
|
|
if (PIOS_RCVR_Init(&pios_dsm_rcvr_id, &pios_dsm_rcvr_driver, pios_dsm_id)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
pios_rcvr_group_map[MANUALCONTROLSETTINGS_CHANNELGROUPS_DSMMAINPORT] = pios_dsm_rcvr_id;
|
|
|
|
}
|
|
|
|
#endif /* PIOS_INCLUDE_DSM */
|
|
|
|
break;
|
|
|
|
case HWSETTINGS_CC_MAINPORT_DEBUGCONSOLE:
|
2012-10-11 00:06:28 -04:00
|
|
|
#if defined(PIOS_INCLUDE_COM)
|
|
|
|
#if defined(PIOS_INCLUDE_DEBUG_CONSOLE)
|
2013-05-19 17:37:30 +03:00
|
|
|
{
|
|
|
|
uint32_t pios_usart_generic_id;
|
|
|
|
if (PIOS_USART_Init(&pios_usart_generic_id, &pios_usart_generic_main_cfg)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
|
2014-06-11 20:11:48 +02:00
|
|
|
uint8_t *tx_buffer = (uint8_t *)pios_malloc(PIOS_COM_DEBUGCONSOLE_TX_BUF_LEN);
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_Assert(tx_buffer);
|
|
|
|
if (PIOS_COM_Init(&pios_com_debug_id, &pios_usart_com_driver, pios_usart_generic_id,
|
|
|
|
NULL, 0,
|
|
|
|
tx_buffer, PIOS_COM_DEBUGCONSOLE_TX_BUF_LEN)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif /* PIOS_INCLUDE_DEBUG_CONSOLE */
|
|
|
|
#endif /* PIOS_INCLUDE_COM */
|
|
|
|
break;
|
|
|
|
case HWSETTINGS_CC_MAINPORT_COMBRIDGE:
|
|
|
|
{
|
|
|
|
uint32_t pios_usart_generic_id;
|
|
|
|
if (PIOS_USART_Init(&pios_usart_generic_id, &pios_usart_generic_main_cfg)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
|
2014-06-11 20:11:48 +02:00
|
|
|
uint8_t *rx_buffer = (uint8_t *)pios_malloc(PIOS_COM_BRIDGE_RX_BUF_LEN);
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_Assert(rx_buffer);
|
2014-06-11 20:11:48 +02:00
|
|
|
uint8_t *tx_buffer = (uint8_t *)pios_malloc(PIOS_COM_BRIDGE_TX_BUF_LEN);
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_Assert(tx_buffer);
|
|
|
|
if (PIOS_COM_Init(&pios_com_bridge_id, &pios_usart_com_driver, pios_usart_generic_id,
|
|
|
|
rx_buffer, PIOS_COM_BRIDGE_RX_BUF_LEN,
|
|
|
|
tx_buffer, PIOS_COM_BRIDGE_TX_BUF_LEN)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case HWSETTINGS_CC_MAINPORT_OSDHK:
|
|
|
|
{
|
|
|
|
uint32_t pios_usart_hkosd_id;
|
|
|
|
if (PIOS_USART_Init(&pios_usart_hkosd_id, &pios_usart_hkosd_main_cfg)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
|
2014-06-11 20:11:48 +02:00
|
|
|
uint8_t *tx_buffer = (uint8_t *)pios_malloc(PIOS_COM_HKOSD_TX_BUF_LEN);
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_Assert(tx_buffer);
|
|
|
|
if (PIOS_COM_Init(&pios_com_hkosd_id, &pios_usart_com_driver, pios_usart_hkosd_id,
|
|
|
|
NULL, 0,
|
|
|
|
tx_buffer, PIOS_COM_HKOSD_TX_BUF_LEN)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Configure the flexi port */
|
|
|
|
uint8_t hwsettings_cc_flexiport;
|
|
|
|
HwSettingsCC_FlexiPortGet(&hwsettings_cc_flexiport);
|
|
|
|
|
|
|
|
switch (hwsettings_cc_flexiport) {
|
|
|
|
case HWSETTINGS_CC_FLEXIPORT_DISABLED:
|
|
|
|
break;
|
|
|
|
case HWSETTINGS_CC_FLEXIPORT_TELEMETRY:
|
bootcfg: use UAVobj to control boot-time HW config
This should mark an end to the compile-time selection of HW
configurations.
Minor changes in board initialization for all platforms:
- Most config structs are marked static to prevent badly written
drivers from directly referring to config data.
- Adapt to changes in .irq fields in config data.
- Adapt to changes in USART IRQ handling.
Major changes in board initialization for CC:
- Use HwSettings UAVObj to decide which drivers to attach to
the "main" port and the flexi port, and select the appropriate
device configuration data.
- HwSettings allows choosing between Disabled, Telemetry, SBUS,
Spektrum,GPS, and I2C for each of the two ports.
- Use ManualControlSettings.InputMode to init/configure the
appropriate receiver module, and register its available rx channels
with the PIOS_RCVR layer. Can choose between PWM, Spektrum and PPM
at board init time. PPM driver is broken, and SBUS will work once
it is added to this UAVObj as an option.
- CC build now includes code for SBUS, Spektrum and PWM receivers in
every firmware image.
PIOS_USART driver:
- Now handles its own low-level IRQs internally
- If NULL upper-level IRQ handler is bound in at board init time
then rx/tx is satisfied by internal PIOS_USART buffered IO routines
which are (typically) attached to the COM layer.
- If an alternate upper-level IRQ handler is bound in at board init
then that handler is called and expected to clear down the USART
IRQ sources. This is used by Spektrum and SBUS drivers.
PIOS_SBUS and PIOS_SPEKTRUM drivers:
- Improved data/API hiding
- No longer assume they know where their config data is stored which
allows for boot-time alternate configurations for the driver.
- Now registers an upper-level IRQ handlerwith the USART layer to
decouple the driver from which USART it is actually attached to.
2011-07-05 20:21:00 -04:00
|
|
|
#if defined(PIOS_INCLUDE_TELEMETRY_RF)
|
2013-05-19 17:37:30 +03:00
|
|
|
{
|
|
|
|
uint32_t pios_usart_generic_id;
|
|
|
|
if (PIOS_USART_Init(&pios_usart_generic_id, &pios_usart_generic_flexi_cfg)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
2014-06-11 20:11:48 +02:00
|
|
|
uint8_t *rx_buffer = (uint8_t *)pios_malloc(PIOS_COM_TELEM_RF_RX_BUF_LEN);
|
|
|
|
uint8_t *tx_buffer = (uint8_t *)pios_malloc(PIOS_COM_TELEM_RF_TX_BUF_LEN);
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_Assert(rx_buffer);
|
|
|
|
PIOS_Assert(tx_buffer);
|
|
|
|
if (PIOS_COM_Init(&pios_com_telem_rf_id, &pios_usart_com_driver, pios_usart_generic_id,
|
|
|
|
rx_buffer, PIOS_COM_TELEM_RF_RX_BUF_LEN,
|
|
|
|
tx_buffer, PIOS_COM_TELEM_RF_TX_BUF_LEN)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
}
|
bootcfg: use UAVobj to control boot-time HW config
This should mark an end to the compile-time selection of HW
configurations.
Minor changes in board initialization for all platforms:
- Most config structs are marked static to prevent badly written
drivers from directly referring to config data.
- Adapt to changes in .irq fields in config data.
- Adapt to changes in USART IRQ handling.
Major changes in board initialization for CC:
- Use HwSettings UAVObj to decide which drivers to attach to
the "main" port and the flexi port, and select the appropriate
device configuration data.
- HwSettings allows choosing between Disabled, Telemetry, SBUS,
Spektrum,GPS, and I2C for each of the two ports.
- Use ManualControlSettings.InputMode to init/configure the
appropriate receiver module, and register its available rx channels
with the PIOS_RCVR layer. Can choose between PWM, Spektrum and PPM
at board init time. PPM driver is broken, and SBUS will work once
it is added to this UAVObj as an option.
- CC build now includes code for SBUS, Spektrum and PWM receivers in
every firmware image.
PIOS_USART driver:
- Now handles its own low-level IRQs internally
- If NULL upper-level IRQ handler is bound in at board init time
then rx/tx is satisfied by internal PIOS_USART buffered IO routines
which are (typically) attached to the COM layer.
- If an alternate upper-level IRQ handler is bound in at board init
then that handler is called and expected to clear down the USART
IRQ sources. This is used by Spektrum and SBUS drivers.
PIOS_SBUS and PIOS_SPEKTRUM drivers:
- Improved data/API hiding
- No longer assume they know where their config data is stored which
allows for boot-time alternate configurations for the driver.
- Now registers an upper-level IRQ handlerwith the USART layer to
decouple the driver from which USART it is actually attached to.
2011-07-05 20:21:00 -04:00
|
|
|
#endif /* PIOS_INCLUDE_TELEMETRY_RF */
|
2013-05-19 17:37:30 +03:00
|
|
|
break;
|
|
|
|
case HWSETTINGS_CC_FLEXIPORT_COMBRIDGE:
|
|
|
|
{
|
|
|
|
uint32_t pios_usart_generic_id;
|
|
|
|
if (PIOS_USART_Init(&pios_usart_generic_id, &pios_usart_generic_flexi_cfg)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
|
2014-06-11 20:11:48 +02:00
|
|
|
uint8_t *rx_buffer = (uint8_t *)pios_malloc(PIOS_COM_BRIDGE_RX_BUF_LEN);
|
|
|
|
uint8_t *tx_buffer = (uint8_t *)pios_malloc(PIOS_COM_BRIDGE_TX_BUF_LEN);
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_Assert(rx_buffer);
|
|
|
|
PIOS_Assert(tx_buffer);
|
|
|
|
if (PIOS_COM_Init(&pios_com_bridge_id, &pios_usart_com_driver, pios_usart_generic_id,
|
|
|
|
rx_buffer, PIOS_COM_BRIDGE_RX_BUF_LEN,
|
|
|
|
tx_buffer, PIOS_COM_BRIDGE_TX_BUF_LEN)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case HWSETTINGS_CC_FLEXIPORT_GPS:
|
2011-02-12 22:19:43 +00:00
|
|
|
#if defined(PIOS_INCLUDE_GPS)
|
2013-05-19 17:37:30 +03:00
|
|
|
{
|
|
|
|
uint32_t pios_usart_generic_id;
|
|
|
|
if (PIOS_USART_Init(&pios_usart_generic_id, &pios_usart_generic_flexi_cfg)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
2014-06-11 20:11:48 +02:00
|
|
|
uint8_t *rx_buffer = (uint8_t *)pios_malloc(PIOS_COM_GPS_RX_BUF_LEN);
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_Assert(rx_buffer);
|
|
|
|
if (PIOS_COM_Init(&pios_com_gps_id, &pios_usart_com_driver, pios_usart_generic_id,
|
|
|
|
rx_buffer, PIOS_COM_GPS_RX_BUF_LEN,
|
|
|
|
NULL, 0)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif /* PIOS_INCLUDE_GPS */
|
|
|
|
break;
|
|
|
|
case HWSETTINGS_CC_FLEXIPORT_PPM:
|
2013-01-19 09:50:51 -07:00
|
|
|
#if defined(PIOS_INCLUDE_PPM_FLEXI)
|
2013-05-19 17:37:30 +03:00
|
|
|
{
|
|
|
|
uint32_t pios_ppm_id;
|
|
|
|
PIOS_PPM_Init(&pios_ppm_id, &pios_ppm_flexi_cfg);
|
|
|
|
|
|
|
|
uint32_t pios_ppm_rcvr_id;
|
|
|
|
if (PIOS_RCVR_Init(&pios_ppm_rcvr_id, &pios_ppm_rcvr_driver, pios_ppm_id)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
pios_rcvr_group_map[MANUALCONTROLSETTINGS_CHANNELGROUPS_PPM] = pios_ppm_rcvr_id;
|
|
|
|
}
|
|
|
|
#endif /* PIOS_INCLUDE_PPM_FLEXI */
|
|
|
|
break;
|
2014-11-22 08:32:00 +11:00
|
|
|
case HWSETTINGS_CC_FLEXIPORT_DSM:
|
2011-11-04 21:40:34 +02:00
|
|
|
#if defined(PIOS_INCLUDE_DSM)
|
2013-05-19 17:37:30 +03:00
|
|
|
{
|
|
|
|
uint32_t pios_usart_dsm_id;
|
|
|
|
if (PIOS_USART_Init(&pios_usart_dsm_id, &pios_usart_dsm_flexi_cfg)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t pios_dsm_id;
|
|
|
|
if (PIOS_DSM_Init(&pios_dsm_id,
|
|
|
|
&pios_dsm_flexi_cfg,
|
|
|
|
&pios_usart_com_driver,
|
|
|
|
pios_usart_dsm_id,
|
2014-11-22 08:32:00 +11:00
|
|
|
hwsettings_DSMxBind)) {
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t pios_dsm_rcvr_id;
|
|
|
|
if (PIOS_RCVR_Init(&pios_dsm_rcvr_id, &pios_dsm_rcvr_driver, pios_dsm_id)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
pios_rcvr_group_map[MANUALCONTROLSETTINGS_CHANNELGROUPS_DSMFLEXIPORT] = pios_dsm_rcvr_id;
|
|
|
|
}
|
|
|
|
#endif /* PIOS_INCLUDE_DSM */
|
|
|
|
break;
|
|
|
|
case HWSETTINGS_CC_FLEXIPORT_DEBUGCONSOLE:
|
2012-10-11 00:06:28 -04:00
|
|
|
#if defined(PIOS_INCLUDE_COM)
|
|
|
|
#if defined(PIOS_INCLUDE_DEBUG_CONSOLE)
|
2013-05-19 17:37:30 +03:00
|
|
|
{
|
|
|
|
uint32_t pios_usart_generic_id;
|
|
|
|
if (PIOS_USART_Init(&pios_usart_generic_id, &pios_usart_generic_flexi_cfg)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
|
2014-06-11 20:11:48 +02:00
|
|
|
uint8_t *tx_buffer = (uint8_t *)pios_malloc(PIOS_COM_DEBUGCONSOLE_TX_BUF_LEN);
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_Assert(tx_buffer);
|
|
|
|
if (PIOS_COM_Init(&pios_com_debug_id, &pios_usart_com_driver, pios_usart_generic_id,
|
|
|
|
NULL, 0,
|
|
|
|
tx_buffer, PIOS_COM_DEBUGCONSOLE_TX_BUF_LEN)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif /* PIOS_INCLUDE_DEBUG_CONSOLE */
|
|
|
|
#endif /* PIOS_INCLUDE_COM */
|
|
|
|
break;
|
|
|
|
case HWSETTINGS_CC_FLEXIPORT_I2C:
|
bootcfg: use UAVobj to control boot-time HW config
This should mark an end to the compile-time selection of HW
configurations.
Minor changes in board initialization for all platforms:
- Most config structs are marked static to prevent badly written
drivers from directly referring to config data.
- Adapt to changes in .irq fields in config data.
- Adapt to changes in USART IRQ handling.
Major changes in board initialization for CC:
- Use HwSettings UAVObj to decide which drivers to attach to
the "main" port and the flexi port, and select the appropriate
device configuration data.
- HwSettings allows choosing between Disabled, Telemetry, SBUS,
Spektrum,GPS, and I2C for each of the two ports.
- Use ManualControlSettings.InputMode to init/configure the
appropriate receiver module, and register its available rx channels
with the PIOS_RCVR layer. Can choose between PWM, Spektrum and PPM
at board init time. PPM driver is broken, and SBUS will work once
it is added to this UAVObj as an option.
- CC build now includes code for SBUS, Spektrum and PWM receivers in
every firmware image.
PIOS_USART driver:
- Now handles its own low-level IRQs internally
- If NULL upper-level IRQ handler is bound in at board init time
then rx/tx is satisfied by internal PIOS_USART buffered IO routines
which are (typically) attached to the COM layer.
- If an alternate upper-level IRQ handler is bound in at board init
then that handler is called and expected to clear down the USART
IRQ sources. This is used by Spektrum and SBUS drivers.
PIOS_SBUS and PIOS_SPEKTRUM drivers:
- Improved data/API hiding
- No longer assume they know where their config data is stored which
allows for boot-time alternate configurations for the driver.
- Now registers an upper-level IRQ handlerwith the USART layer to
decouple the driver from which USART it is actually attached to.
2011-07-05 20:21:00 -04:00
|
|
|
#if defined(PIOS_INCLUDE_I2C)
|
2013-05-19 17:37:30 +03:00
|
|
|
{
|
|
|
|
if (PIOS_I2C_Init(&pios_i2c_flexi_adapter_id, &pios_i2c_flexi_adapter_cfg)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif /* PIOS_INCLUDE_I2C */
|
|
|
|
break;
|
|
|
|
case HWSETTINGS_CC_FLEXIPORT_OSDHK:
|
|
|
|
{
|
|
|
|
uint32_t pios_usart_hkosd_id;
|
|
|
|
if (PIOS_USART_Init(&pios_usart_hkosd_id, &pios_usart_hkosd_flexi_cfg)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
|
2014-06-11 20:11:48 +02:00
|
|
|
uint8_t *tx_buffer = (uint8_t *)pios_malloc(PIOS_COM_HKOSD_TX_BUF_LEN);
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_Assert(tx_buffer);
|
|
|
|
if (PIOS_COM_Init(&pios_com_hkosd_id, &pios_usart_com_driver, pios_usart_hkosd_id,
|
|
|
|
NULL, 0,
|
|
|
|
tx_buffer, PIOS_COM_HKOSD_TX_BUF_LEN)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Configure the rcvr port */
|
|
|
|
uint8_t hwsettings_rcvrport;
|
|
|
|
HwSettingsCC_RcvrPortGet(&hwsettings_rcvrport);
|
|
|
|
|
2015-02-15 19:08:49 +01:00
|
|
|
switch ((HwSettingsCC_RcvrPortOptions)hwsettings_rcvrport) {
|
2015-02-08 17:36:42 +01:00
|
|
|
case HWSETTINGS_CC_RCVRPORT_DISABLEDONESHOT:
|
2013-03-28 18:20:50 +02:00
|
|
|
#if defined(PIOS_INCLUDE_HCSR04)
|
2013-05-19 17:37:30 +03:00
|
|
|
{
|
|
|
|
uint32_t pios_hcsr04_id;
|
|
|
|
PIOS_HCSR04_Init(&pios_hcsr04_id, &pios_hcsr04_cfg);
|
|
|
|
}
|
2013-03-28 18:20:50 +02:00
|
|
|
#endif
|
2013-05-19 17:37:30 +03:00
|
|
|
break;
|
2015-02-08 17:36:42 +01:00
|
|
|
case HWSETTINGS_CC_RCVRPORT_PWMNOONESHOT:
|
bootcfg: use UAVobj to control boot-time HW config
This should mark an end to the compile-time selection of HW
configurations.
Minor changes in board initialization for all platforms:
- Most config structs are marked static to prevent badly written
drivers from directly referring to config data.
- Adapt to changes in .irq fields in config data.
- Adapt to changes in USART IRQ handling.
Major changes in board initialization for CC:
- Use HwSettings UAVObj to decide which drivers to attach to
the "main" port and the flexi port, and select the appropriate
device configuration data.
- HwSettings allows choosing between Disabled, Telemetry, SBUS,
Spektrum,GPS, and I2C for each of the two ports.
- Use ManualControlSettings.InputMode to init/configure the
appropriate receiver module, and register its available rx channels
with the PIOS_RCVR layer. Can choose between PWM, Spektrum and PPM
at board init time. PPM driver is broken, and SBUS will work once
it is added to this UAVObj as an option.
- CC build now includes code for SBUS, Spektrum and PWM receivers in
every firmware image.
PIOS_USART driver:
- Now handles its own low-level IRQs internally
- If NULL upper-level IRQ handler is bound in at board init time
then rx/tx is satisfied by internal PIOS_USART buffered IO routines
which are (typically) attached to the COM layer.
- If an alternate upper-level IRQ handler is bound in at board init
then that handler is called and expected to clear down the USART
IRQ sources. This is used by Spektrum and SBUS drivers.
PIOS_SBUS and PIOS_SPEKTRUM drivers:
- Improved data/API hiding
- No longer assume they know where their config data is stored which
allows for boot-time alternate configurations for the driver.
- Now registers an upper-level IRQ handlerwith the USART layer to
decouple the driver from which USART it is actually attached to.
2011-07-05 20:21:00 -04:00
|
|
|
#if defined(PIOS_INCLUDE_PWM)
|
2013-05-19 17:37:30 +03:00
|
|
|
{
|
|
|
|
uint32_t pios_pwm_id;
|
|
|
|
PIOS_PWM_Init(&pios_pwm_id, &pios_pwm_cfg);
|
|
|
|
|
|
|
|
uint32_t pios_pwm_rcvr_id;
|
|
|
|
if (PIOS_RCVR_Init(&pios_pwm_rcvr_id, &pios_pwm_rcvr_driver, pios_pwm_id)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
pios_rcvr_group_map[MANUALCONTROLSETTINGS_CHANNELGROUPS_PWM] = pios_pwm_rcvr_id;
|
|
|
|
}
|
|
|
|
#endif /* PIOS_INCLUDE_PWM */
|
|
|
|
break;
|
2015-02-08 17:36:42 +01:00
|
|
|
case HWSETTINGS_CC_RCVRPORT_PPMNOONESHOT:
|
|
|
|
case HWSETTINGS_CC_RCVRPORT_PPMOUTPUTSNOONESHOT:
|
2015-02-22 13:25:07 +01:00
|
|
|
case HWSETTINGS_CC_RCVRPORT_PPM_PIN8ONESHOT:
|
bootcfg: use UAVobj to control boot-time HW config
This should mark an end to the compile-time selection of HW
configurations.
Minor changes in board initialization for all platforms:
- Most config structs are marked static to prevent badly written
drivers from directly referring to config data.
- Adapt to changes in .irq fields in config data.
- Adapt to changes in USART IRQ handling.
Major changes in board initialization for CC:
- Use HwSettings UAVObj to decide which drivers to attach to
the "main" port and the flexi port, and select the appropriate
device configuration data.
- HwSettings allows choosing between Disabled, Telemetry, SBUS,
Spektrum,GPS, and I2C for each of the two ports.
- Use ManualControlSettings.InputMode to init/configure the
appropriate receiver module, and register its available rx channels
with the PIOS_RCVR layer. Can choose between PWM, Spektrum and PPM
at board init time. PPM driver is broken, and SBUS will work once
it is added to this UAVObj as an option.
- CC build now includes code for SBUS, Spektrum and PWM receivers in
every firmware image.
PIOS_USART driver:
- Now handles its own low-level IRQs internally
- If NULL upper-level IRQ handler is bound in at board init time
then rx/tx is satisfied by internal PIOS_USART buffered IO routines
which are (typically) attached to the COM layer.
- If an alternate upper-level IRQ handler is bound in at board init
then that handler is called and expected to clear down the USART
IRQ sources. This is used by Spektrum and SBUS drivers.
PIOS_SBUS and PIOS_SPEKTRUM drivers:
- Improved data/API hiding
- No longer assume they know where their config data is stored which
allows for boot-time alternate configurations for the driver.
- Now registers an upper-level IRQ handlerwith the USART layer to
decouple the driver from which USART it is actually attached to.
2011-07-05 20:21:00 -04:00
|
|
|
#if defined(PIOS_INCLUDE_PPM)
|
2013-05-19 17:37:30 +03:00
|
|
|
{
|
|
|
|
uint32_t pios_ppm_id;
|
2015-02-22 13:25:07 +01:00
|
|
|
if (hwsettings_rcvrport == HWSETTINGS_CC_RCVRPORT_PPM_PIN8ONESHOT) {
|
|
|
|
PIOS_PPM_Init(&pios_ppm_id, &pios_ppm_pin8_cfg);
|
2015-02-12 00:00:17 +01:00
|
|
|
} else {
|
|
|
|
PIOS_PPM_Init(&pios_ppm_id, &pios_ppm_cfg);
|
|
|
|
}
|
2013-05-19 17:37:30 +03:00
|
|
|
|
|
|
|
uint32_t pios_ppm_rcvr_id;
|
|
|
|
if (PIOS_RCVR_Init(&pios_ppm_rcvr_id, &pios_ppm_rcvr_driver, pios_ppm_id)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
pios_rcvr_group_map[MANUALCONTROLSETTINGS_CHANNELGROUPS_PPM] = pios_ppm_rcvr_id;
|
|
|
|
}
|
|
|
|
#endif /* PIOS_INCLUDE_PPM */
|
|
|
|
break;
|
2015-02-08 17:36:42 +01:00
|
|
|
case HWSETTINGS_CC_RCVRPORT_PPMPWMNOONESHOT:
|
2013-05-19 17:37:30 +03:00
|
|
|
/* This is a combination of PPM and PWM inputs */
|
2012-09-29 19:09:27 -04:00
|
|
|
#if defined(PIOS_INCLUDE_PPM)
|
2013-05-19 17:37:30 +03:00
|
|
|
{
|
|
|
|
uint32_t pios_ppm_id;
|
|
|
|
PIOS_PPM_Init(&pios_ppm_id, &pios_ppm_cfg);
|
|
|
|
|
|
|
|
uint32_t pios_ppm_rcvr_id;
|
|
|
|
if (PIOS_RCVR_Init(&pios_ppm_rcvr_id, &pios_ppm_rcvr_driver, pios_ppm_id)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
pios_rcvr_group_map[MANUALCONTROLSETTINGS_CHANNELGROUPS_PPM] = pios_ppm_rcvr_id;
|
|
|
|
}
|
|
|
|
#endif /* PIOS_INCLUDE_PPM */
|
2012-09-29 19:09:27 -04:00
|
|
|
#if defined(PIOS_INCLUDE_PWM)
|
2013-05-19 17:37:30 +03:00
|
|
|
{
|
|
|
|
uint32_t pios_pwm_id;
|
|
|
|
PIOS_PWM_Init(&pios_pwm_id, &pios_pwm_with_ppm_cfg);
|
|
|
|
|
|
|
|
uint32_t pios_pwm_rcvr_id;
|
|
|
|
if (PIOS_RCVR_Init(&pios_pwm_rcvr_id, &pios_pwm_rcvr_driver, pios_pwm_id)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
pios_rcvr_group_map[MANUALCONTROLSETTINGS_CHANNELGROUPS_PWM] = pios_pwm_rcvr_id;
|
|
|
|
}
|
|
|
|
#endif /* PIOS_INCLUDE_PWM */
|
|
|
|
break;
|
2015-02-15 19:08:49 +01:00
|
|
|
case HWSETTINGS_CC_RCVRPORT_OUTPUTSONESHOT:
|
|
|
|
break;
|
2013-05-19 17:37:30 +03:00
|
|
|
}
|
2011-02-12 22:19:43 +00:00
|
|
|
|
2011-07-28 08:22:47 -04:00
|
|
|
#if defined(PIOS_INCLUDE_GCSRCVR)
|
2013-05-19 17:37:30 +03:00
|
|
|
GCSReceiverInitialize();
|
|
|
|
uint32_t pios_gcsrcvr_id;
|
|
|
|
PIOS_GCSRCVR_Init(&pios_gcsrcvr_id);
|
|
|
|
uint32_t pios_gcsrcvr_rcvr_id;
|
|
|
|
if (PIOS_RCVR_Init(&pios_gcsrcvr_rcvr_id, &pios_gcsrcvr_rcvr_driver, pios_gcsrcvr_id)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
pios_rcvr_group_map[MANUALCONTROLSETTINGS_CHANNELGROUPS_GCS] = pios_gcsrcvr_rcvr_id;
|
|
|
|
#endif /* PIOS_INCLUDE_GCSRCVR */
|
|
|
|
|
|
|
|
/* Remap AFIO pin for PB4 (Servo 5 Out)*/
|
|
|
|
GPIO_PinRemapConfig(GPIO_Remap_SWJ_NoJTRST, ENABLE);
|
2011-08-12 23:23:16 -04:00
|
|
|
|
2013-04-26 17:59:52 +03:00
|
|
|
#ifndef PIOS_ENABLE_DEBUG_PINS
|
2015-02-15 19:08:49 +01:00
|
|
|
switch ((HwSettingsCC_RcvrPortOptions)hwsettings_rcvrport) {
|
2015-02-08 17:36:42 +01:00
|
|
|
case HWSETTINGS_CC_RCVRPORT_DISABLEDONESHOT:
|
|
|
|
case HWSETTINGS_CC_RCVRPORT_PWMNOONESHOT:
|
|
|
|
case HWSETTINGS_CC_RCVRPORT_PPMNOONESHOT:
|
|
|
|
case HWSETTINGS_CC_RCVRPORT_PPMPWMNOONESHOT:
|
2015-02-22 13:25:07 +01:00
|
|
|
case HWSETTINGS_CC_RCVRPORT_PPM_PIN8ONESHOT:
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_Servo_Init(&pios_servo_cfg);
|
|
|
|
break;
|
2015-02-08 17:36:42 +01:00
|
|
|
case HWSETTINGS_CC_RCVRPORT_PPMOUTPUTSNOONESHOT:
|
|
|
|
case HWSETTINGS_CC_RCVRPORT_OUTPUTSONESHOT:
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_Servo_Init(&pios_servo_rcvr_cfg);
|
|
|
|
break;
|
|
|
|
}
|
2011-08-12 23:23:16 -04:00
|
|
|
#else
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_DEBUG_Init(pios_tim_servoport_all_pins, NELEMENTS(pios_tim_servoport_all_pins));
|
|
|
|
#endif /* PIOS_ENABLE_DEBUG_PINS */
|
2012-01-20 14:52:05 -06:00
|
|
|
|
2013-05-19 17:37:30 +03:00
|
|
|
switch (bdinfo->board_rev) {
|
|
|
|
case BOARD_REVISION_CC:
|
|
|
|
// Revision 1 with invensense gyros, start the ADC
|
2012-03-26 00:22:59 -05:00
|
|
|
#if defined(PIOS_INCLUDE_ADC)
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_ADC_Init(&pios_adc_cfg);
|
2012-03-26 00:22:59 -05:00
|
|
|
#endif
|
2012-01-24 10:32:42 -06:00
|
|
|
#if defined(PIOS_INCLUDE_ADXL345)
|
2013-05-19 17:37:30 +03:00
|
|
|
PIOS_ADXL345_Init(pios_spi_flash_accel_id, 0);
|
2012-01-24 10:32:42 -06:00
|
|
|
#endif
|
2013-05-19 17:37:30 +03:00
|
|
|
break;
|
|
|
|
case BOARD_REVISION_CC3D:
|
|
|
|
// Revision 2 with MPU6000 gyros, start a SPI interface and connect to it
|
|
|
|
GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable, ENABLE);
|
2012-01-20 15:45:22 -06:00
|
|
|
|
2012-03-26 00:22:59 -05:00
|
|
|
#if defined(PIOS_INCLUDE_MPU6000)
|
2013-05-19 17:37:30 +03:00
|
|
|
// Set up the SPI interface to the serial flash
|
|
|
|
if (PIOS_SPI_Init(&pios_spi_gyro_id, &pios_spi_gyro_cfg)) {
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
|
|
|
PIOS_MPU6000_Init(pios_spi_gyro_id, 0, &pios_mpu6000_cfg);
|
|
|
|
PIOS_MPU6000_CONFIG_Configure();
|
2015-01-11 17:09:11 +01:00
|
|
|
init_test = !PIOS_MPU6000_Driver.test(0);
|
2012-03-26 00:22:59 -05:00
|
|
|
#endif /* PIOS_INCLUDE_MPU6000 */
|
2012-01-24 01:25:53 -06:00
|
|
|
|
2013-05-19 17:37:30 +03:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
PIOS_Assert(0);
|
|
|
|
}
|
2012-01-24 01:25:53 -06:00
|
|
|
|
2013-05-19 17:37:30 +03:00
|
|
|
/* Make sure we have at least one telemetry link configured or else fail initialization */
|
|
|
|
PIOS_Assert(pios_com_telem_rf_id || pios_com_telem_usb_id);
|
2015-02-09 00:51:46 +01:00
|
|
|
|
|
|
|
// Attach the board config check hook
|
|
|
|
SANITYCHECK_AttachHook(&CopterControlConfigHook);
|
2015-02-11 23:59:23 +01:00
|
|
|
// trigger a config check if actuatorsettings are updated
|
|
|
|
ActuatorSettingsInitialize();
|
|
|
|
ActuatorSettingsConnectCallback(ActuatorSettingsUpdatedCb);
|
2011-02-12 22:19:43 +00:00
|
|
|
}
|
|
|
|
|
2015-02-09 00:51:46 +01:00
|
|
|
SystemAlarmsExtendedAlarmStatusOptions CopterControlConfigHook()
|
|
|
|
{
|
|
|
|
// inhibit usage of oneshot for non supported RECEIVER port modes
|
|
|
|
uint8_t recmode;
|
|
|
|
|
|
|
|
HwSettingsCC_RcvrPortGet(&recmode);
|
2015-02-15 19:08:49 +01:00
|
|
|
uint8_t flexiMode;
|
2015-02-11 23:59:23 +01:00
|
|
|
uint8_t modes[ACTUATORSETTINGS_BANKMODE_NUMELEM];
|
|
|
|
ActuatorSettingsBankModeGet(modes);
|
2015-02-15 19:08:49 +01:00
|
|
|
HwSettingsCC_FlexiPortGet(&flexiMode);
|
|
|
|
|
2015-02-09 00:51:46 +01:00
|
|
|
switch ((HwSettingsCC_RcvrPortOptions)recmode) {
|
|
|
|
// Those modes allows oneshot usage
|
|
|
|
case HWSETTINGS_CC_RCVRPORT_DISABLEDONESHOT:
|
|
|
|
case HWSETTINGS_CC_RCVRPORT_OUTPUTSONESHOT:
|
2015-02-22 13:25:07 +01:00
|
|
|
case HWSETTINGS_CC_RCVRPORT_PPM_PIN8ONESHOT:
|
|
|
|
if ((recmode == HWSETTINGS_CC_RCVRPORT_PPM_PIN8ONESHOT ||
|
2015-02-15 19:08:49 +01:00
|
|
|
flexiMode == HWSETTINGS_CC_FLEXIPORT_PPM) &&
|
2015-02-17 23:20:07 +01:00
|
|
|
(modes[3] == ACTUATORSETTINGS_BANKMODE_PWMSYNC ||
|
2015-02-15 19:08:49 +01:00
|
|
|
modes[3] == ACTUATORSETTINGS_BANKMODE_ONESHOT125)) {
|
2015-02-11 23:59:23 +01:00
|
|
|
return SYSTEMALARMS_EXTENDEDALARMSTATUS_UNSUPPORTEDCONFIG_ONESHOT;
|
|
|
|
} else {
|
|
|
|
return SYSTEMALARMS_EXTENDEDALARMSTATUS_NONE;
|
|
|
|
}
|
|
|
|
|
2015-02-09 00:51:46 +01:00
|
|
|
// inhibit oneshot for the following modes
|
|
|
|
case HWSETTINGS_CC_RCVRPORT_PPMNOONESHOT:
|
|
|
|
case HWSETTINGS_CC_RCVRPORT_PPMOUTPUTSNOONESHOT:
|
|
|
|
case HWSETTINGS_CC_RCVRPORT_PPMPWMNOONESHOT:
|
|
|
|
case HWSETTINGS_CC_RCVRPORT_PWMNOONESHOT:
|
|
|
|
for (uint8_t i = 0; i < ACTUATORSETTINGS_BANKMODE_NUMELEM; i++) {
|
2015-02-17 23:20:07 +01:00
|
|
|
if (modes[i] == ACTUATORSETTINGS_BANKMODE_PWMSYNC ||
|
2015-02-09 00:51:46 +01:00
|
|
|
modes[i] == ACTUATORSETTINGS_BANKMODE_ONESHOT125) {
|
|
|
|
return SYSTEMALARMS_EXTENDEDALARMSTATUS_UNSUPPORTEDCONFIG_ONESHOT;;
|
|
|
|
}
|
2015-02-11 23:59:23 +01:00
|
|
|
|
|
|
|
return SYSTEMALARMS_EXTENDEDALARMSTATUS_NONE;
|
2015-02-09 00:51:46 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return SYSTEMALARMS_EXTENDEDALARMSTATUS_UNSUPPORTEDCONFIG_ONESHOT;;
|
|
|
|
}
|
2015-02-11 23:59:23 +01:00
|
|
|
// trigger a configuration check if ActuatorSettings are changed.
|
|
|
|
void ActuatorSettingsUpdatedCb(__attribute__((unused)) UAVObjEvent *ev)
|
|
|
|
{
|
|
|
|
configuration_check();
|
|
|
|
}
|
|
|
|
|
2011-01-14 01:38:19 +00:00
|
|
|
/**
|
|
|
|
* @}
|
|
|
|
*/
|