mirror of
https://bitbucket.org/librepilot/librepilot.git
synced 2025-01-17 02:52:12 +01:00
Flight/Settings: Remove old settings implementation (replaced with binary settings as UAVObjects)
git-svn-id: svn://svn.openpilot.org/OpenPilot/trunk@465 ebee16cc-31ac-478f-84a7-5cbb03baadba
This commit is contained in:
parent
ac88f788be
commit
f4c4b1371a
@ -71,8 +71,6 @@ OPUAVTALK = ./UAVTalk
|
||||
OPUAVTALKINC = $(OPUAVTALK)/inc
|
||||
OPUAVOBJ = ./UAVObjects
|
||||
OPUAVOBJINC = $(OPUAVOBJ)/inc
|
||||
OPSETTINGS = ./Settings
|
||||
OPSETTINGSINC = $(OPSETTINGS)/inc
|
||||
OPTESTS = ./Tests
|
||||
OPMODULEDIR = ./Modules
|
||||
MODEXAMPLE = $(OPMODULEDIR)/Example
|
||||
@ -153,7 +151,6 @@ SRC += $(PIOSSTM32F10X)/pios_exti.c
|
||||
|
||||
## PIOS Hardware (Common)
|
||||
SRC += $(PIOSCOMMON)/pios_sdcard.c
|
||||
SRC += $(PIOSCOMMON)/pios_settings.c
|
||||
SRC += $(PIOSCOMMON)/pios_com.c
|
||||
SRC += $(PIOSCOMMON)/pios_bmp085.c
|
||||
SRC += $(PIOSCOMMON)/printf-stdarg.c
|
||||
@ -246,8 +243,6 @@ EXTRAINCDIRS += $(OPUAVTALK)
|
||||
EXTRAINCDIRS += $(OPUAVTALKINC)
|
||||
EXTRAINCDIRS += $(OPUAVOBJ)
|
||||
EXTRAINCDIRS += $(OPUAVOBJINC)
|
||||
EXTRAINCDIRS += $(OPSETTINGS)
|
||||
EXTRAINCDIRS += $(OPSETTINGSINC)
|
||||
EXTRAINCDIRS += $(MODEXAMPLE)
|
||||
EXTRAINCDIRS += $(MODEXAMPLEINC)
|
||||
EXTRAINCDIRS += $(MODTELEMETRY)
|
||||
|
@ -69,7 +69,7 @@ int main()
|
||||
for(;;)
|
||||
{
|
||||
/* Check if we have an SD Card with the correct settings files on it */
|
||||
if(!PIOS_SDCARD_MountFS(STARTUP_LOG_ENABLED) && !PIOS_Settings_CheckForFiles()) {
|
||||
if(!PIOS_SDCARD_MountFS(STARTUP_LOG_ENABLED)) {
|
||||
/* Found one without errors */
|
||||
break;
|
||||
}
|
||||
@ -88,9 +88,6 @@ int main()
|
||||
UAVObjInitialize();
|
||||
UAVObjectsInitializeAll();
|
||||
|
||||
/* Call LoadSettings which populates global variables so the rest of the hardware can be configured. */
|
||||
PIOS_Settings_Load();
|
||||
|
||||
/* Com ports init */
|
||||
PIOS_COM_Init();
|
||||
|
||||
|
@ -1,116 +0,0 @@
|
||||
/**
|
||||
******************************************************************************
|
||||
*
|
||||
* @file pios_settings.c
|
||||
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
|
||||
* @brief Gets and sets PiOS settings, normally from SDCard.
|
||||
* @see The GNU Public License (GPL) Version 3
|
||||
* @defgroup PIOS_SETTINGS Settings Functions
|
||||
* @{
|
||||
*
|
||||
*****************************************************************************/
|
||||
/*
|
||||
* 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
|
||||
*/
|
||||
|
||||
|
||||
/* Project Includes */
|
||||
#include "pios.h"
|
||||
|
||||
#if defined(PIOS_INCLUDE_SETTINGS)
|
||||
|
||||
|
||||
/* Private Function Prototypes */
|
||||
|
||||
|
||||
/* Local Variables */
|
||||
SettingsTypeDef Settings;
|
||||
|
||||
|
||||
/**
|
||||
* Populate System global Settings into Structs using MinIni, defaults are also set here via macros from pios_config.h
|
||||
*/
|
||||
/* Value Reading: ini_getl("Section", "Key", (DefaultValue), IniFile); */
|
||||
/* String Reading: ini_gets("Section", "Key", "DefaultValue", StrBuffer, sizearray(StrBuffer), IniFile); */
|
||||
void PIOS_Settings_Load(void)
|
||||
{
|
||||
/* Unused yet, until we load strings
|
||||
char StrBuffer[100];
|
||||
long Result;
|
||||
*/
|
||||
|
||||
/* Section: GPS */
|
||||
Settings.GPS.Baudrate = (uint32_t) ini_getl("GPS", "Baudrate", GPS_BAUDRATE, SETTINGS_FILE);
|
||||
|
||||
/* Section: Telemetry */
|
||||
Settings.Telem.Baudrate = (uint32_t) ini_getl("Telemetry", "Baudrate", TELEM_BAUDRATE, SETTINGS_FILE);
|
||||
|
||||
/* Section: Auxillary_USART */
|
||||
Settings.AuxUSART.Enabled = (bool) ini_getl("Auxillary_USART", "Enabled", AUXUART_ENABLED, SETTINGS_FILE);
|
||||
Settings.AuxUSART.Baudrate = (uint32_t) ini_getl("Auxillary_USART", "Baudrate", AUXUART_BAUDRATE, SETTINGS_FILE);
|
||||
|
||||
/* Section: Servos */
|
||||
Settings.Servos.PositionMin = (uint16_t) ini_getl("Servos", "PositionMin", SERVOS_POSITION_MIN, SETTINGS_FILE);
|
||||
Settings.Servos.PositionMax = (uint16_t) ini_getl("Servos", "PositionMax", SERVOS_POSITION_MAX, SETTINGS_FILE);
|
||||
}
|
||||
|
||||
/**
|
||||
* Dump Settings struct contents to UART
|
||||
* \param[in] USARTx USART name (GPS, TELEM, AUX)
|
||||
*/
|
||||
void PIOS_Settings_Dump(USART_TypeDef* USARTx)
|
||||
{
|
||||
/* Implement once UART is fully implemented */
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if settings files exist on the drive
|
||||
* \return 0 All files found
|
||||
* \return >0 Number of files missing
|
||||
*/
|
||||
int32_t PIOS_Settings_CheckForFiles(void)
|
||||
{
|
||||
DIRINFO di;
|
||||
DIRENT de;
|
||||
int FoundCount = 0;
|
||||
|
||||
di.scratch = PIOS_SDCARD_Sector;
|
||||
|
||||
/* Open the root directory */
|
||||
DFS_OpenDir(&PIOS_SDCARD_VolInfo, (uint8_t *)"", &di);
|
||||
|
||||
/* Scan the directory for all files */
|
||||
while(!DFS_GetNext(&PIOS_SDCARD_VolInfo, &di, &de)) {
|
||||
if(de.name[0]) {
|
||||
uint8_t file_name[13];
|
||||
DFS_DirToCanonical((char *)file_name, (char *)de.name);
|
||||
|
||||
if(strcmp((char *)file_name, SETTINGS_FILE) == 0) {
|
||||
FoundCount++;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/* If one or more files are missing, return the number of missing files */
|
||||
if(FoundCount != 1)
|
||||
{
|
||||
return FoundCount;
|
||||
}
|
||||
|
||||
/* All files found */
|
||||
return 0;
|
||||
}
|
||||
|
||||
#endif
|
@ -160,11 +160,11 @@ void PIOS_Servo_Set(uint8_t Servo, uint16_t Position)
|
||||
if (Servo < PIOS_SERVO_NUM_OUTPUTS && Servo >= 0)
|
||||
{
|
||||
/* Clip servo position */
|
||||
if(Position < Settings.Servos.PositionMin) {
|
||||
Position = Settings.Servos.PositionMin;
|
||||
if(Position < SERVOS_POSITION_MIN) {
|
||||
Position = SERVOS_POSITION_MIN;
|
||||
}
|
||||
if(Position > Settings.Servos.PositionMax) {
|
||||
Position = Settings.Servos.PositionMax;
|
||||
if(Position > SERVOS_POSITION_MAX) {
|
||||
Position = SERVOS_POSITION_MAX;
|
||||
}
|
||||
|
||||
/* Update the position */
|
||||
|
@ -34,7 +34,6 @@
|
||||
|
||||
|
||||
/* Global Variables */
|
||||
extern SettingsTypeDef Settings;
|
||||
xSemaphoreHandle PIOS_USART1_Buffer;
|
||||
xSemaphoreHandle PIOS_USART2_Buffer;
|
||||
xSemaphoreHandle PIOS_USART3_Buffer;
|
||||
|
@ -1,64 +0,0 @@
|
||||
/**
|
||||
******************************************************************************
|
||||
*
|
||||
* @file pios_settings.h
|
||||
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
|
||||
* @brief Settings functions header
|
||||
* @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
|
||||
*/
|
||||
|
||||
#ifndef PIOS_SETTINGS_H
|
||||
#define PIOS_SETTINGS_H
|
||||
|
||||
|
||||
/* Global types */
|
||||
typedef struct {
|
||||
uint32_t Baudrate;
|
||||
} GPSSettingsTypeDef;
|
||||
|
||||
typedef struct {
|
||||
uint32_t Baudrate;
|
||||
} TelemSettingsTypeDef;
|
||||
|
||||
typedef struct {
|
||||
bool Enabled;
|
||||
uint32_t Baudrate;
|
||||
} USARTSettingsTypeDef;
|
||||
|
||||
typedef struct {
|
||||
uint16_t PositionMin;
|
||||
uint16_t PositionMax;
|
||||
} ServosSettingsTypeDef;
|
||||
|
||||
typedef struct {
|
||||
GPSSettingsTypeDef GPS;
|
||||
TelemSettingsTypeDef Telem;
|
||||
USARTSettingsTypeDef AuxUSART;
|
||||
ServosSettingsTypeDef Servos;
|
||||
} SettingsTypeDef;
|
||||
|
||||
/*Global Variables */
|
||||
extern SettingsTypeDef Settings;
|
||||
|
||||
/* Public Functions */
|
||||
extern void PIOS_Settings_Load(void);
|
||||
extern void PIOS_Settings_Dump(USART_TypeDef* USARTx);
|
||||
extern int32_t PIOS_Settings_CheckForFiles(void);
|
||||
|
||||
#endif /* PIOS_SETTINGS_H */
|
@ -84,7 +84,6 @@
|
||||
#endif
|
||||
|
||||
/* PIOS Hardware Includes (Common) */
|
||||
#include <pios_settings.h>
|
||||
#include <pios_sdcard.h>
|
||||
#include <pios_com.h>
|
||||
#if defined(PIOS_INCLUDE_BMP085)
|
||||
|
Loading…
x
Reference in New Issue
Block a user