Subversion Repositories Projects

Rev

Rev 426 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
426 killagreg 1
/*#######################################################################################*/
2
/* !!! THIS IS NOT FREE SOFTWARE !!!                                                     */
3
/*#######################################################################################*/
4
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
5
// + Copyright (c) 2008 Ingo Busker, Holger Buss
6
// + Nur für den privaten Gebrauch
7
// + FOR NON COMMERCIAL USE ONLY
8
// + www.MikroKopter.com
9
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
10
// + Es gilt für das gesamte Projekt (Hardware, Software, Binärfiles, Sourcecode und Dokumentation),
11
// + dass eine Nutzung (auch auszugsweise) nur für den privaten (nicht-kommerziellen) Gebrauch zulässig ist.
12
// + Sollten direkte oder indirekte kommerzielle Absichten verfolgt werden, ist mit uns (info@mikrokopter.de) Kontakt
13
// + bzgl. der Nutzungsbedingungen aufzunehmen.
14
// + Eine kommerzielle Nutzung ist z.B.Verkauf von MikroKoptern, Bestückung und Verkauf von Platinen oder Bausätzen,
15
// + Verkauf von Luftbildaufnahmen, usw.
16
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
17
// + Werden Teile des Quellcodes (mit oder ohne Modifikation) weiterverwendet oder veröffentlicht,
18
// + unterliegen sie auch diesen Nutzungsbedingungen und diese Nutzungsbedingungen incl. Copyright müssen dann beiliegen
19
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
20
// + Sollte die Software (auch auszugesweise) oder sonstige Informationen des MikroKopter-Projekts
21
// + auf anderen Webseiten oder sonstigen Medien veröffentlicht werden, muss unsere Webseite "http://www.mikrokopter.de"
22
// + eindeutig als Ursprung verlinkt werden
23
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
24
// + Keine Gewähr auf Fehlerfreiheit, Vollständigkeit oder Funktion
25
// + Benutzung auf eigene Gefahr
26
// + Wir übernehmen keinerlei Haftung für direkte oder indirekte Personen- oder Sachschäden
27
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
28
// + Die PORTIERUNG der Software (oder Teile davon) auf andere Systeme (ausser der Hardware von www.mikrokopter.de) ist nur
29
// + mit unserer Zustimmung zulässig
30
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
31
// + Die Funktion printf_P() unterliegt ihrer eigenen Lizenz und ist hiervon nicht betroffen
32
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
33
// + Redistributions of source code (with or without modifications) must retain the above copyright notice,
34
// + this list of conditions and the following disclaimer.
35
// +   * Neither the name of the copyright holders nor the names of contributors may be used to endorse or promote products derived
36
// +     from this software without specific prior written permission.
37
// +   * The use of this project (hardware, software, binary files, sources and documentation) is only permitted
38
// +     for non-commercial use (directly or indirectly)
39
// +     Commercial use (for excample: selling of MikroKopters, selling of PCBs, assembly, ...) is only permitted
40
// +     with our written permission
41
// +   * If sources or documentations are redistributet on other webpages, out webpage (http://www.MikroKopter.de) must be
42
// +     clearly linked as origin
43
// +   * PORTING this software (or part of it) to systems (other than hardware from www.mikrokopter.de) is NOT allowed
44
//
45
// +  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
46
// +  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
47
// +  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
48
// +  ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
49
// +  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
50
// +  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
51
// +  SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
52
// +  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
53
// +  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
54
// +  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
55
// +  POSSIBILITY OF SUCH DAMAGE.
56
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
57
#include <stdio.h>
58
#include <stdlib.h>
59
#include <string.h>
60
#include "printf_P.h"
61
#include "fat16.h"
62
#include "settings.h"
63
#include "uart0.h"
64
 
65
typedef struct
66
{
67
        ParamId_t ParamId;
68
        int8_t   Name[17]; // 0 terminator is the last byte
69
        uint8_t   Group;   // 0 = reserved  1,2,3,4
70
        uint16_t  Value;
71
        uint16_t  Default;
72
        uint16_t  Min;
73
        uint16_t  Max;
74
} __attribute__((packed)) Parameter_t;
75
 
76
Parameter_t CFG_Parameter[] =
77
{
78
  //{PID             , "1234567890123456" , Group, Value, Default,   Min,       Max },
79
        {PID_KML_LOGGING , "KMLLogging      " ,     1,   500,     500,    0,    60000}, // the log interval for KML logging, 0 = off
80
        {PID_GPX_LOGGING , "GPXLogging      " ,     1,  1000,    1000,    0,    60000}   // the log interval for GPX logging, 0 = off
81
};
82
 
83
 
84
//----------------------------------------------------------------------------------
85
// initialize all parameters by its default value
86
void Settings_SetDefaultValues(void)
87
{
88
        uint8_t i;
89
        // run thrue all parameters and set value to default
90
        for (i = 0; i < sizeof(CFG_Parameter) / sizeof(Parameter_t); i++)
91
        {
92
                CFG_Parameter[i].Value  = CFG_Parameter[i].Default;
93
        }
94
}
95
 
96
//----------------------------------------------------------------------------------
97
// set parameter from string based name and value
98
uint8_t Settings_SetParameterFromString(int8_t *name, int8_t *value)
99
{
100
        uint8_t i, retval = 0;
101
        int8_t string[] = "                \0"; // null terminated string of 16 characters
102
 
103
        if((name == NULL) || (value == NULL)) return(retval);
104
 
105
        i = strlen(name);                                       // lenght of the parameter name
106
        if (i > 16) i = 16;                                     // cut off at 16
107
 
108
        memcpy(string, name, i);                        // copy name to local buffer
109
 
110
    // search name in parameter list
111
        for (i = 0; i < sizeof(CFG_Parameter) / sizeof(Parameter_t); i++)
112
        {
113
                if(strncmp(string, CFG_Parameter[i].Name, 16) == 0) // names are matching
114
                {
115
                        CFG_Parameter[i].Value = (uint16_t)atoi(value); // convert string to number and set value
116
                        // out of range ?
117
                        if((CFG_Parameter[i].Value < CFG_Parameter[i].Min) || (CFG_Parameter[i].Value > CFG_Parameter[i].Max))
118
                        {       // print a warning
119
                                printf("\r\n%s <-- %d is out of range [%d...%d]", string, CFG_Parameter[i].Value, CFG_Parameter[i].Min, CFG_Parameter[i].Max);
120
                                CFG_Parameter[i].Value = CFG_Parameter[i].Default;  // fallback to default
121
                        }
122
                        retval = 1; // value in range
123
                        break; // end loop
124
                }
125
        }
126
        if(!retval)
127
        {
128
                printf("\r\n%s <-- unknown parameter\r\n", string);
129
        }
130
        return(retval);
131
}
132
 
133
//----------------------------------------------------------------------------------
134
// read settings from file on sd-card
135
void Settings_Init(void)
136
{
137
        #define LINE_MAX 32
138
        File_t *fp;
139
        int8_t settingsline[LINE_MAX];
140
        char *name, *value;
141
        uint8_t i;
142
        char *tmp;
143
 
144
        printf("\r\n Settings init...");
145
        Settings_SetDefaultValues();
146
 
147
        if(Fat16_IsValid())
148
        {       // check if settings file is existing
149
                if(fexist_("settings.ini"))
150
                {
151
                        fp = fopen_("settings.ini", 'r');               // try to open the file
152
                        if (fp == NULL)                                                 // could not open the file
153
                        {
154
                                printf("ERROR: Opening settings file!");
155
                                return;
156
                        }
157
                        // read all lines from file
436 killagreg 158
                        while(fgets_(settingsline, LINE_MAX, fp) != NULL)
426 killagreg 159
                        {
160
                                if ( // ignorelines starting with \r,\n,' ',';','#'
161
                                        (settingsline[0] != '\n') &&
162
                                        (settingsline[0] != '\r') &&
163
                                        (settingsline[0] != ' ' ) &&
164
                                        (settingsline[0] != ';' ) &&
165
                                        (settingsline[0] != '#' )
166
                                        )
167
                                {
168
                                        name  = strtok_r(settingsline, "=", & tmp); // get name
169
                                        value = strtok_r(NULL, "=", & tmp); // get value
170
                                        if ((name != NULL) && (value != NULL))
171
                                        {
172
                                                Settings_SetParameterFromString(name, value);
173
                                        }
174
                                }
175
                        }
176
                        fclose_(fp);
177
                        printf("ok");
178
                        return;
179
                }
180
                else // settings file does not exist
181
                {       // create default settings file
182
                        fp = fopen_("settings.ini", 'w');               // try to open the file
183
                        if(fp == NULL)
184
                        {
185
                                printf("ERROR: Creating default settings file!");
186
                                return;
187
                        }
188
                        // run thrue all parameters and set value to default
189
                        for (i = 0; i < sizeof(CFG_Parameter) / sizeof(Parameter_t); i++)
190
                        {
191
                                sprintf(settingsline, "%s = %d\r\n", CFG_Parameter[i].Name, CFG_Parameter[i].Default);
192
                                fputs_(settingsline, fp); // write to file
193
                        }
194
                        fputs_("\r\n", fp); // newline at the end of file
195
                        fclose_(fp);
196
                        printf("Default settings file created!");
197
                        return;
198
                }
199
        }
200
        else // no acces to fat 16 filesystem
201
        {
202
                printf("Using default values!");
203
                return;
204
        }
205
}
206
 
207
 
208
//----------------------------------------------------------------------------------
209
// read value of a paramter identified by its id
210
// returns 1 on success and 0 on error
211
uint8_t Settings_GetParamValue(ParamId_t Pid, uint16_t * pValue)
212
{
213
        uint8_t i, retval = 0;
214
 
215
        for (i = 0; i < sizeof(CFG_Parameter) / sizeof(Parameter_t); i++)
216
        {
217
                if(CFG_Parameter[i].ParamId == Pid)
218
                {
219
                        *pValue = CFG_Parameter[i].Value;
220
                        retval = 1;
221
                        break;
222
                }
223
        }
224
        return retval;
225
}