2011-12-31 04:53:09 +01:00
|
|
|
/**
|
|
|
|
******************************************************************************
|
|
|
|
* @addtogroup OpenPilotModules OpenPilot Modules
|
2013-05-19 16:37:30 +02:00
|
|
|
* @{
|
2011-12-31 04:53:09 +01:00
|
|
|
* @addtogroup FaultModule Fault Module
|
|
|
|
* @brief Insert various fault conditions for testing
|
2013-05-19 16:37:30 +02:00
|
|
|
* @{
|
2011-12-31 04:53:09 +01:00
|
|
|
*
|
2012-01-03 05:28:53 +01:00
|
|
|
* @file Fault.c
|
2011-12-31 04:53:09 +01:00
|
|
|
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
|
|
|
|
* @brief Fault module, inserts faults for testing
|
|
|
|
* @see The GNU Public License (GPL) Version 3
|
|
|
|
*
|
|
|
|
*****************************************************************************/
|
|
|
|
/*
|
|
|
|
* 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
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* 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
|
|
|
|
* for more details.
|
|
|
|
*
|
|
|
|
* 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.,
|
|
|
|
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
*/
|
|
|
|
|
|
|
|
// ****************
|
|
|
|
|
|
|
|
#include "openpilot.h"
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include "hwsettings.h"
|
|
|
|
#include "faultsettings.h"
|
|
|
|
|
|
|
|
static bool module_enabled;
|
|
|
|
static uint8_t active_fault;
|
|
|
|
|
|
|
|
static int32_t fault_initialize(void)
|
|
|
|
{
|
2013-03-25 15:02:16 +01:00
|
|
|
#ifdef MODULE_FAULT_BUILTIN
|
2013-05-19 16:37:30 +02:00
|
|
|
module_enabled = true;
|
2012-01-14 22:55:55 +01:00
|
|
|
#else
|
2013-05-19 16:37:30 +02:00
|
|
|
uint8_t optionalModules[HWSETTINGS_OPTIONALMODULES_NUMELEM];
|
2011-12-31 04:53:09 +01:00
|
|
|
|
2013-05-19 16:37:30 +02:00
|
|
|
HwSettingsOptionalModulesGet(optionalModules);
|
2011-12-31 04:53:09 +01:00
|
|
|
|
2013-05-19 16:37:30 +02:00
|
|
|
if (optionalModules[HWSETTINGS_OPTIONALMODULES_FAULT] == HWSETTINGS_OPTIONALMODULES_ENABLED) {
|
|
|
|
module_enabled = true;
|
|
|
|
} else {
|
|
|
|
module_enabled = false;
|
|
|
|
}
|
2012-01-14 22:55:55 +01:00
|
|
|
#endif
|
2011-12-31 04:53:09 +01:00
|
|
|
|
2013-05-19 16:37:30 +02:00
|
|
|
/* Do this outside the module_enabled test so that it
|
|
|
|
* can be changed even when the module has been disabled.
|
|
|
|
* This is important so we can remove faults even when
|
|
|
|
* we've booted in BootFault recovery mode with all optional
|
|
|
|
* modules disabled.
|
|
|
|
*/
|
|
|
|
|
|
|
|
if (module_enabled) {
|
|
|
|
FaultSettingsActivateFaultGet(&active_fault);
|
|
|
|
|
|
|
|
switch (active_fault) {
|
|
|
|
case FAULTSETTINGS_ACTIVATEFAULT_MODULEINITASSERT:
|
|
|
|
/* Simulate an assert during module init */
|
|
|
|
PIOS_Assert(0);
|
|
|
|
break;
|
|
|
|
case FAULTSETTINGS_ACTIVATEFAULT_INITOUTOFMEMORY:
|
|
|
|
/* Leak all available memory */
|
2014-06-11 20:11:48 +02:00
|
|
|
while (pios_malloc(10)) {
|
2013-05-19 16:37:30 +02:00
|
|
|
;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case FAULTSETTINGS_ACTIVATEFAULT_INITBUSERROR:
|
|
|
|
{
|
|
|
|
/* Force a bad access */
|
|
|
|
uint32_t *bad_ptr = (uint32_t *)0xFFFFFFFF;
|
|
|
|
*bad_ptr = 0xAA55AA55;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
2011-12-31 04:53:09 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static void fault_task(void *parameters);
|
|
|
|
|
|
|
|
static int32_t fault_start(void)
|
|
|
|
{
|
2013-05-19 16:37:30 +02:00
|
|
|
xTaskHandle fault_task_handle;
|
|
|
|
|
|
|
|
if (module_enabled) {
|
|
|
|
switch (active_fault) {
|
|
|
|
case FAULTSETTINGS_ACTIVATEFAULT_RUNAWAYTASK:
|
|
|
|
case FAULTSETTINGS_ACTIVATEFAULT_TASKOUTOFMEMORY:
|
|
|
|
xTaskCreate(fault_task,
|
|
|
|
(signed char *)"Fault",
|
|
|
|
configMINIMAL_STACK_SIZE,
|
|
|
|
NULL,
|
|
|
|
configMAX_PRIORITIES - 1,
|
|
|
|
&fault_task_handle);
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return -1;
|
2011-12-31 04:53:09 +01:00
|
|
|
}
|
2013-06-04 05:37:40 +02:00
|
|
|
MODULE_INITCALL(fault_initialize, fault_start);
|
2011-12-31 04:53:09 +01:00
|
|
|
|
2013-05-19 16:37:30 +02:00
|
|
|
static void fault_task(__attribute__((unused)) void *parameters)
|
2011-12-31 04:53:09 +01:00
|
|
|
{
|
2013-05-19 16:37:30 +02:00
|
|
|
switch (active_fault) {
|
|
|
|
case FAULTSETTINGS_ACTIVATEFAULT_RUNAWAYTASK:
|
|
|
|
/* Consume all realtime, not letting the systemtask run */
|
|
|
|
while (1) {
|
|
|
|
;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case FAULTSETTINGS_ACTIVATEFAULT_TASKOUTOFMEMORY:
|
|
|
|
/* Leak all available memory and then sleep */
|
2014-06-11 20:11:48 +02:00
|
|
|
while (pios_malloc(10)) {
|
2013-05-19 16:37:30 +02:00
|
|
|
;
|
|
|
|
}
|
|
|
|
while (1) {
|
|
|
|
vTaskDelay(1000);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
2011-12-31 04:53:09 +01:00
|
|
|
}
|
|
|
|
|
2013-05-19 16:37:30 +02:00
|
|
|
/**
|
|
|
|
* @}
|
|
|
|
* @}
|
|
|
|
*/
|