Subversion Repositories FlightCtrl

Rev

Rev 1942 | Rev 1957 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 1942 Rev 1944
1
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
2
// + Copyright (c) Holger Buss, Ingo Busker
2
// + Copyright (c) Holger Buss, Ingo Busker
3
// + Nur für den privaten Gebrauch
3
// + Nur für den privaten Gebrauch
4
// + porting the sources to other systems or using the software on other systems (except hardware from www.mikrokopter.de) is not allowed
4
// + porting the sources to other systems or using the software on other systems (except hardware from www.mikrokopter.de) is not allowed
5
// + www.MikroKopter.com
5
// + www.MikroKopter.com
6
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
6
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
7
// + Es gilt für das gesamte Projekt (Hardware, Software, Binärfiles, Sourcecode und Dokumentation),
7
// + Es gilt für das gesamte Projekt (Hardware, Software, Binärfiles, Sourcecode und Dokumentation),
8
// + dass eine Nutzung (auch auszugsweise) nur für den privaten (nicht-kommerziellen) Gebrauch zulässig ist.
8
// + dass eine Nutzung (auch auszugsweise) nur für den privaten (nicht-kommerziellen) Gebrauch zulässig ist.
9
// + Sollten direkte oder indirekte kommerzielle Absichten verfolgt werden, ist mit uns (info@mikrokopter.de) Kontakt
9
// + Sollten direkte oder indirekte kommerzielle Absichten verfolgt werden, ist mit uns (info@mikrokopter.de) Kontakt
10
// + bzgl. der Nutzungsbedingungen aufzunehmen.
10
// + bzgl. der Nutzungsbedingungen aufzunehmen.
11
// + Eine kommerzielle Nutzung ist z.B.Verkauf von MikroKoptern, Bestückung und Verkauf von Platinen oder Bausätzen,
11
// + Eine kommerzielle Nutzung ist z.B.Verkauf von MikroKoptern, Bestückung und Verkauf von Platinen oder Bausätzen,
12
// + Verkauf von Luftbildaufnahmen, usw.
12
// + Verkauf von Luftbildaufnahmen, usw.
13
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
13
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
14
// + Werden Teile des Quellcodes (mit oder ohne Modifikation) weiterverwendet oder veröffentlicht,
14
// + Werden Teile des Quellcodes (mit oder ohne Modifikation) weiterverwendet oder veröffentlicht,
15
// + unterliegen sie auch diesen Nutzungsbedingungen und diese Nutzungsbedingungen incl. Copyright müssen dann beiliegen
15
// + unterliegen sie auch diesen Nutzungsbedingungen und diese Nutzungsbedingungen incl. Copyright müssen dann beiliegen
16
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
16
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
17
// + Sollte die Software (auch auszugesweise) oder sonstige Informationen des MikroKopter-Projekts
17
// + Sollte die Software (auch auszugesweise) oder sonstige Informationen des MikroKopter-Projekts
18
// + auf anderen Webseiten oder sonstigen Medien veröffentlicht werden, muss unsere Webseite "http://www.mikrokopter.de"
18
// + auf anderen Webseiten oder sonstigen Medien veröffentlicht werden, muss unsere Webseite "http://www.mikrokopter.de"
19
// + eindeutig als Ursprung verlinkt werden
19
// + eindeutig als Ursprung verlinkt werden
20
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
20
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
21
// + Keine Gewähr auf Fehlerfreiheit, Vollständigkeit oder Funktion
21
// + Keine Gewähr auf Fehlerfreiheit, Vollständigkeit oder Funktion
22
// + Benutzung auf eigene Gefahr
22
// + Benutzung auf eigene Gefahr
23
// + Wir übernehmen keinerlei Haftung für direkte oder indirekte Personen- oder Sachschäden
23
// + Wir übernehmen keinerlei Haftung für direkte oder indirekte Personen- oder Sachschäden
24
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
24
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
25
// + Die Portierung der Software (oder Teile davon) auf andere Systeme (ausser der Hardware von www.mikrokopter.de) ist nur
25
// + Die Portierung der Software (oder Teile davon) auf andere Systeme (ausser der Hardware von www.mikrokopter.de) ist nur
26
// + mit unserer Zustimmung zulässig
26
// + mit unserer Zustimmung zulässig
27
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
27
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
28
// + Die Funktion printf_P() unterliegt ihrer eigenen Lizenz und ist hiervon nicht betroffen
28
// + Die Funktion printf_P() unterliegt ihrer eigenen Lizenz und ist hiervon nicht betroffen
29
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
29
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
30
// + Redistributions of source code (with or without modifications) must retain the above copyright notice,
30
// + Redistributions of source code (with or without modifications) must retain the above copyright notice,
31
// + this list of conditions and the following disclaimer.
31
// + this list of conditions and the following disclaimer.
32
// +   * Neither the name of the copyright holders nor the names of contributors may be used to endorse or promote products derived
32
// +   * Neither the name of the copyright holders nor the names of contributors may be used to endorse or promote products derived
33
// +     from this software without specific prior written permission.
33
// +     from this software without specific prior written permission.
34
// +   * The use of this project (hardware, software, binary files, sources and documentation) is only permittet
34
// +   * The use of this project (hardware, software, binary files, sources and documentation) is only permittet
35
// +     for non-commercial use (directly or indirectly)
35
// +     for non-commercial use (directly or indirectly)
36
// +     Commercial use (for excample: selling of MikroKopters, selling of PCBs, assembly, ...) is only permitted
36
// +     Commercial use (for excample: selling of MikroKopters, selling of PCBs, assembly, ...) is only permitted
37
// +     with our written permission
37
// +     with our written permission
38
// +   * If sources or documentations are redistributet on other webpages, out webpage (http://www.MikroKopter.de) must be
38
// +   * If sources or documentations are redistributet on other webpages, out webpage (http://www.MikroKopter.de) must be
39
// +     clearly linked as origin
39
// +     clearly linked as origin
40
// +   * porting to systems other than hardware from www.mikrokopter.de is not allowed
40
// +   * porting to systems other than hardware from www.mikrokopter.de is not allowed
41
// +  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
41
// +  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
42
// +  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
42
// +  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
43
// +  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
43
// +  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
44
// +  ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
44
// +  ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
45
// +  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
45
// +  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
46
// +  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
46
// +  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
47
// +  SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
47
// +  SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
48
// +  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN// +  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
48
// +  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN// +  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
49
// +  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
49
// +  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
50
// +  POSSIBILITY OF SUCH DAMAGE.
50
// +  POSSIBILITY OF SUCH DAMAGE.
51
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
51
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
52
 
52
 
53
 
53
 
54
#ifndef EEMEM
54
#ifndef EEMEM
55
#define EEMEM __attribute__ ((section (".eeprom")))
55
#define EEMEM __attribute__ ((section (".eeprom")))
56
#endif
56
#endif
57
 
57
 
58
 
58
 
59
#include <avr/eeprom.h>
59
#include <avr/eeprom.h>
60
#include <string.h>
60
#include <string.h>
61
#include "eeprom.h"
61
#include "eeprom.h"
62
#include "uart.h"
62
#include "uart.h"
63
#include "led.h"
63
#include "led.h"
64
#include "main.h"
64
#include "main.h"
65
#include "fc.h"
65
#include "fc.h"
66
#include "twimaster.h"
66
#include "twimaster.h"
67
 
67
 
68
paramset_t              EE_Parameter;
68
paramset_t              EE_Parameter;
69
MixerTable_t    Mixer;
69
MixerTable_t    Mixer;
70
uint8_t RequiredMotors;
70
uint8_t RequiredMotors;
71
 
71
 
72
 
72
 
73
uint8_t RAM_Checksum(uint8_t* pBuffer, uint16_t len)
73
uint8_t RAM_Checksum(uint8_t* pBuffer, uint16_t len)
74
{
74
{
75
        uint8_t crc = 0xAA;
75
        uint8_t crc = 0xAA;
76
        uint16_t i;
76
        uint16_t i;
77
 
77
 
78
        for(i=0; i<len; i++)
78
        for(i=0; i<len; i++)
79
        {
79
        {
80
                crc += pBuffer[i];
80
                crc += pBuffer[i];
81
        }
81
        }
82
        return crc;
82
        return crc;
83
}
83
}
84
 
84
 
85
uint8_t EEProm_Checksum(uint16_t EEAddr, uint16_t len)
85
uint8_t EEProm_Checksum(uint16_t EEAddr, uint16_t len)
86
{
86
{
87
        uint8_t crc = 0xAA;
87
        uint8_t crc = 0xAA;
88
        uint16_t off;
88
        uint16_t off;
89
 
89
 
90
        for(off=0; off<len; off++)
90
        for(off=0; off<len; off++)
91
        {
91
        {
92
                crc += eeprom_read_byte((uint8_t*)(EEAddr + off));;
92
                crc += eeprom_read_byte((uint8_t*)(EEAddr + off));;
93
        }
93
        }
94
        return crc;
94
        return crc;
95
}
95
}
96
 
96
 
97
void ParamSet_DefaultStickMapping(void)
97
void ParamSet_DefaultStickMapping(void)
98
{
98
{
99
        EE_Parameter.Kanalbelegung[K_GAS]   = 1;
99
        EE_Parameter.Kanalbelegung[K_GAS]   = 1;
100
        EE_Parameter.Kanalbelegung[K_ROLL]  = 2;
100
        EE_Parameter.Kanalbelegung[K_ROLL]  = 2;
101
        EE_Parameter.Kanalbelegung[K_NICK]  = 3;
101
        EE_Parameter.Kanalbelegung[K_NICK]  = 3;
102
        EE_Parameter.Kanalbelegung[K_GIER]  = 4;
102
        EE_Parameter.Kanalbelegung[K_GIER]  = 4;
103
        EE_Parameter.Kanalbelegung[K_POTI1] = 5;
103
        EE_Parameter.Kanalbelegung[K_POTI1] = 5;
104
        EE_Parameter.Kanalbelegung[K_POTI2] = 6;
104
        EE_Parameter.Kanalbelegung[K_POTI2] = 6;
105
        EE_Parameter.Kanalbelegung[K_POTI3] = 7;
105
        EE_Parameter.Kanalbelegung[K_POTI3] = 7;
106
        EE_Parameter.Kanalbelegung[K_POTI4] = 8;
106
        EE_Parameter.Kanalbelegung[K_POTI4] = 8;
107
        EE_Parameter.Kanalbelegung[K_POTI5] = 9;
107
        EE_Parameter.Kanalbelegung[K_POTI5] = 9;
108
        EE_Parameter.Kanalbelegung[K_POTI6] = 10;
108
        EE_Parameter.Kanalbelegung[K_POTI6] = 10;
109
        EE_Parameter.Kanalbelegung[K_POTI7] = 11;
109
        EE_Parameter.Kanalbelegung[K_POTI7] = 11;
110
        EE_Parameter.Kanalbelegung[K_POTI8] = 12;
110
        EE_Parameter.Kanalbelegung[K_POTI8] = 12;
111
}
111
}
112
 
112
 
113
 
113
 
114
/***************************************************/
114
/***************************************************/
115
/*    Default Values for parameter set 1           */
115
/*    Default Values for parameter set 1           */
116
/***************************************************/
116
/***************************************************/
117
void CommonDefaults(void)
117
void CommonDefaults(void)
118
{
118
{
119
        EE_Parameter.Revision = EEPARAM_REVISION;
119
        EE_Parameter.Revision = EEPARAM_REVISION;
120
 
120
 
121
        if(PlatinenVersion >= 20)
121
        if(PlatinenVersion >= 20)
122
        {
122
        {
123
                EE_Parameter.Gyro_D = 10;
123
                EE_Parameter.Gyro_D = 10;
124
                EE_Parameter.Driftkomp = 0;
124
                EE_Parameter.Driftkomp = 0;
125
                EE_Parameter.GyroAccFaktor = 27;
125
                EE_Parameter.GyroAccFaktor = 27;
126
                EE_Parameter.WinkelUmschlagNick = 78;
126
                EE_Parameter.WinkelUmschlagNick = 78;
127
                EE_Parameter.WinkelUmschlagRoll = 78;
127
                EE_Parameter.WinkelUmschlagRoll = 78;
128
        }
128
        }
129
        else
129
        else
130
        {
130
        {
131
                EE_Parameter.Gyro_D = 3;
131
                EE_Parameter.Gyro_D = 3;
132
                EE_Parameter.Driftkomp = 32;
132
                EE_Parameter.Driftkomp = 32;
133
                EE_Parameter.GyroAccFaktor = 30;
133
                EE_Parameter.GyroAccFaktor = 30;
134
                EE_Parameter.WinkelUmschlagNick = 85;
134
                EE_Parameter.WinkelUmschlagNick = 85;
135
                EE_Parameter.WinkelUmschlagRoll = 85;
135
                EE_Parameter.WinkelUmschlagRoll = 85;
136
        }
136
        }
137
        EE_Parameter.GlobalConfig = CFG_ACHSENKOPPLUNG_AKTIV | CFG_KOMPASS_AKTIV | CFG_GPS_AKTIV | CFG_HOEHEN_SCHALTER;
137
        EE_Parameter.GlobalConfig = CFG_ACHSENKOPPLUNG_AKTIV | CFG_KOMPASS_AKTIV | CFG_GPS_AKTIV | CFG_HOEHEN_SCHALTER;
138
        EE_Parameter.ExtraConfig = CFG_GPS_AID | CFG2_VARIO_BEEP;
138
        EE_Parameter.ExtraConfig = CFG_GPS_AID | CFG2_VARIO_BEEP;
139
        EE_Parameter.Receiver = RECEIVER_JETI;
139
        EE_Parameter.Receiver = RECEIVER_JETI;
140
        EE_Parameter.MotorSafetySwitch = 0;
140
        EE_Parameter.MotorSafetySwitch = 0;
141
        EE_Parameter.ExternalControl = 0;
141
        EE_Parameter.ExternalControl = 0;
142
 
142
 
143
        EE_Parameter.Gas_Min = 8;             // Wert : 0-32
143
        EE_Parameter.Gas_Min = 8;             // Wert : 0-32
144
        EE_Parameter.Gas_Max = 230;           // Wert : 33-247
144
        EE_Parameter.Gas_Max = 230;           // Wert : 33-247
145
        EE_Parameter.KompassWirkung = 64;    // Wert : 0-247
145
        EE_Parameter.KompassWirkung = 64;    // Wert : 0-247
146
 
146
 
147
        EE_Parameter.Hoehe_MinGas = 30;
147
        EE_Parameter.Hoehe_MinGas = 30;
148
        EE_Parameter.MaxHoehe     = 255;         // Wert : 0-247   255 -> Poti1
148
        EE_Parameter.MaxHoehe     = 255;         // Wert : 0-247   255 -> Poti1
149
        EE_Parameter.Hoehe_P      = 15;          // Wert : 0-32
149
        EE_Parameter.Hoehe_P      = 15;          // Wert : 0-32
150
        EE_Parameter.Luftdruck_D  = 30;          // Wert : 0-247
150
        EE_Parameter.Luftdruck_D  = 30;          // Wert : 0-247
151
        EE_Parameter.Hoehe_ACC_Wirkung = 0;     // Wert : 0-247
151
        EE_Parameter.Hoehe_ACC_Wirkung = 0;     // Wert : 0-247
152
        EE_Parameter.Hoehe_HoverBand = 8;         // Wert : 0-247
152
        EE_Parameter.Hoehe_HoverBand = 8;         // Wert : 0-247
153
        EE_Parameter.Hoehe_GPS_Z = 64;           // Wert : 0-247
153
        EE_Parameter.Hoehe_GPS_Z = 64;           // Wert : 0-247
154
        EE_Parameter.Hoehe_StickNeutralPoint = 0;// Wert : 0-247 (0 = Hover-Estimation)
154
        EE_Parameter.Hoehe_StickNeutralPoint = 0;// Wert : 0-247 (0 = Hover-Estimation)
155
        EE_Parameter.Hoehe_Verstaerkung = 15;    // Wert : 0-50 (15 -> ca. +/- 5m/sek bei Stick-Voll-Ausschlag)
155
        EE_Parameter.Hoehe_Verstaerkung = 15;    // Wert : 0-50 (15 -> ca. +/- 5m/sek bei Stick-Voll-Ausschlag)
156
 
156
 
157
        EE_Parameter.UserParam1 =   0;           // zur freien Verwendung
157
        EE_Parameter.UserParam1 =   0;           // zur freien Verwendung
158
        EE_Parameter.UserParam2 =   0;           // zur freien Verwendung
158
        EE_Parameter.UserParam2 =   0;           // zur freien Verwendung
159
        EE_Parameter.UserParam3 =   0;           // zur freien Verwendung
159
        EE_Parameter.UserParam3 =   0;           // zur freien Verwendung
160
        EE_Parameter.UserParam4 =   0;           // zur freien Verwendung
160
        EE_Parameter.UserParam4 =   0;           // zur freien Verwendung
161
        EE_Parameter.UserParam5 =   0;           // zur freien Verwendung
161
        EE_Parameter.UserParam5 =   0;           // zur freien Verwendung
162
        EE_Parameter.UserParam6 =   0;           // zur freien Verwendung
162
        EE_Parameter.UserParam6 =   0;           // zur freien Verwendung
163
        EE_Parameter.UserParam7 = 0;             // zur freien Verwendung
163
        EE_Parameter.UserParam7 = 0;             // zur freien Verwendung
164
        EE_Parameter.UserParam8 = 0;             // zur freien Verwendung
164
        EE_Parameter.UserParam8 = 0;             // zur freien Verwendung
165
 
165
 
166
        EE_Parameter.ServoNickControl = 128;     // Wert : 0-247     // Stellung des Servos
166
        EE_Parameter.ServoNickControl = 128;     // Wert : 0-247     // Stellung des Servos
167
        EE_Parameter.ServoNickComp = 50;         // Wert : 0-247     // Einfluss Gyro/Servo
167
        EE_Parameter.ServoNickComp = 50;         // Wert : 0-247     // Einfluss Gyro/Servo
168
        EE_Parameter.ServoCompInvert = 2;        // Wert : 0-247     // Richtung Einfluss Gyro/Servo
168
        EE_Parameter.ServoCompInvert = 2;        // Wert : 0-247     // Richtung Einfluss Gyro/Servo
169
        EE_Parameter.ServoNickMin = 15;          // Wert : 0-247     // Anschlag
169
        EE_Parameter.ServoNickMin = 15;          // Wert : 0-247     // Anschlag
170
        EE_Parameter.ServoNickMax = 230;         // Wert : 0-247     // Anschlag
170
        EE_Parameter.ServoNickMax = 230;         // Wert : 0-247     // Anschlag
171
        EE_Parameter.ServoNickRefresh = 4;
171
        EE_Parameter.ServoNickRefresh = 4;
172
        EE_Parameter.Servo3 = 125;
172
        EE_Parameter.Servo3 = 125;
173
        EE_Parameter.Servo4 = 125;
173
        EE_Parameter.Servo4 = 125;
174
        EE_Parameter.Servo5 = 125;
174
        EE_Parameter.Servo5 = 125;
175
        EE_Parameter.ServoRollControl = 128;     // Wert : 0-247     // Stellung des Servos
175
        EE_Parameter.ServoRollControl = 128;     // Wert : 0-247     // Stellung des Servos
176
        EE_Parameter.ServoRollComp = 85;         // Wert : 0-247     // Einfluss Gyro/Servo
176
        EE_Parameter.ServoRollComp = 85;         // Wert : 0-247     // Einfluss Gyro/Servo
177
        EE_Parameter.ServoRollMin = 70;          // Wert : 0-247     // Anschlag
177
        EE_Parameter.ServoRollMin = 70;          // Wert : 0-247     // Anschlag
178
        EE_Parameter.ServoRollMax = 220;         // Wert : 0-247     // Anschlag
178
        EE_Parameter.ServoRollMax = 220;         // Wert : 0-247     // Anschlag
179
        EE_Parameter.ServoManualControlSpeed = 60;
179
        EE_Parameter.ServoManualControlSpeed = 60;
180
        EE_Parameter.CamOrientation = 0;         // Wert : 0-24 -> 0-360 -> 15° steps
180
        EE_Parameter.CamOrientation = 0;         // Wert : 0-24 -> 0-360 -> 15° steps
181
 
181
 
182
        EE_Parameter.J16Bitmask = 95;
182
        EE_Parameter.J16Bitmask = 95;
183
        EE_Parameter.J17Bitmask = 243;
183
        EE_Parameter.J17Bitmask = 243;
184
        EE_Parameter.WARN_J16_Bitmask = 0xAA;
184
        EE_Parameter.WARN_J16_Bitmask = 0xAA;
185
        EE_Parameter.WARN_J17_Bitmask = 0xAA;
185
        EE_Parameter.WARN_J17_Bitmask = 0xAA;
186
        EE_Parameter.J16Timing = 20;
186
        EE_Parameter.J16Timing = 20;
187
        EE_Parameter.J17Timing = 20;
187
        EE_Parameter.J17Timing = 20;
188
 
188
 
189
        EE_Parameter.LoopGasLimit = 50;
189
        EE_Parameter.LoopGasLimit = 50;
190
        EE_Parameter.LoopThreshold = 90;         // Wert: 0-247  Schwelle für Stickausschlag
190
        EE_Parameter.LoopThreshold = 90;         // Wert: 0-247  Schwelle für Stickausschlag
191
        EE_Parameter.LoopHysterese = 50;
191
        EE_Parameter.LoopHysterese = 50;
192
        EE_Parameter.BitConfig = 0;              // Bitcodiert: 0x01=oben, 0x02=unten, 0x04=links, 0x08=rechts / wird getrennt behandelt
192
        EE_Parameter.BitConfig = 0;              // Bitcodiert: 0x01=oben, 0x02=unten, 0x04=links, 0x08=rechts / wird getrennt behandelt
193
 
193
 
194
        EE_Parameter.NaviGpsModeControl = 254; // 254 -> Poti 2
194
        EE_Parameter.NaviGpsModeControl = 254; // 254 -> Poti 2
195
        EE_Parameter.NaviGpsGain = 100;
195
        EE_Parameter.NaviGpsGain = 100;
196
        EE_Parameter.NaviGpsP = 90;
196
        EE_Parameter.NaviGpsP = 90;
197
        EE_Parameter.NaviGpsI = 90;
197
        EE_Parameter.NaviGpsI = 90;
198
        EE_Parameter.NaviGpsD = 90;
198
        EE_Parameter.NaviGpsD = 90;
199
        EE_Parameter.NaviGpsPLimit = 75;
199
        EE_Parameter.NaviGpsPLimit = 75;
200
        EE_Parameter.NaviGpsILimit = 85;
200
        EE_Parameter.NaviGpsILimit = 85;
201
        EE_Parameter.NaviGpsDLimit = 75;
201
        EE_Parameter.NaviGpsDLimit = 75;
202
        EE_Parameter.NaviGpsACC = 0;
202
        EE_Parameter.NaviGpsACC = 0;
203
        EE_Parameter.NaviGpsMinSat = 6;
203
        EE_Parameter.NaviGpsMinSat = 6;
204
        EE_Parameter.NaviStickThreshold = 8;
204
        EE_Parameter.NaviStickThreshold = 8;
205
        EE_Parameter.NaviWindCorrection = 90;
205
        EE_Parameter.NaviWindCorrection = 90;
206
        EE_Parameter.NaviAccCompensation = 42;
206
        EE_Parameter.NaviAccCompensation = 42;
207
        EE_Parameter.NaviOperatingRadius = 245;
207
        EE_Parameter.NaviOperatingRadius = 245;
208
        EE_Parameter.NaviAngleLimitation = 140;
208
        EE_Parameter.NaviAngleLimitation = 140;
209
        EE_Parameter.NaviPH_LoginTime = 5;
209
        EE_Parameter.NaviPH_LoginTime = 5;
210
        EE_Parameter.OrientationAngle = 0;
210
        EE_Parameter.OrientationAngle = 0;
211
        EE_Parameter.CareFreeModeControl = 0;
211
        EE_Parameter.CareFreeModeControl = 0;
212
        EE_Parameter.UnterspannungsWarnung = 33; // Wert : 0-247 ( Automatische Zellenerkennung bei < 50)
212
        EE_Parameter.UnterspannungsWarnung = 33; // Wert : 0-247 ( Automatische Zellenerkennung bei < 50)
213
        EE_Parameter.NotGas = 45;                // Wert : 0-247     // Gaswert bei Empangsverlust
213
        EE_Parameter.NotGas = 45;                // Wert : 0-247     // Gaswert bei Empangsverlust
214
        EE_Parameter.NotGasZeit = 90;            // Wert : 0-247     // Zeit bis auf NotGas geschaltet wird, wg. Rx-Problemen
214
        EE_Parameter.NotGasZeit = 90;            // Wert : 0-247     // Zeit bis auf NotGas geschaltet wird, wg. Rx-Problemen
215
        EE_Parameter.MotorSmooth = 0;          
215
        EE_Parameter.MotorSmooth = 0;          
216
        EE_Parameter.ComingHomeAltitude = 0;      // 0 = don't change 
216
        EE_Parameter.ComingHomeAltitude = 0;      // 0 = don't change 
217
        EE_Parameter.FailSafeTime = 0;            // 0 = off
217
        EE_Parameter.FailSafeTime = 0;            // 0 = off
218
        EE_Parameter.MaxAltitude = 150;           // 0 = off
218
        EE_Parameter.MaxAltitude = 150;           // 0 = off
-
 
219
        EE_Parameter.AchsKopplung1 = 90;
-
 
220
        EE_Parameter.AchsKopplung2 = 55;
219
}
221
}
220
 
222
/*
221
void ParamSet_DefaultSet1(void) // sport
223
void ParamSet_DefaultSet1(void) // sport
222
{
224
{
223
        CommonDefaults();
225
        CommonDefaults();
224
        EE_Parameter.Stick_P = 14;            // Wert : 1-20
226
        EE_Parameter.Stick_P = 14;            // Wert : 1-20
225
        EE_Parameter.Stick_D = 16;            // Wert : 0-20
227
        EE_Parameter.Stick_D = 16;            // Wert : 0-20
226
        EE_Parameter.Gier_P = 12;             // Wert : 1-20
228
        EE_Parameter.StickGier_P = 12;             // Wert : 1-20
227
        EE_Parameter.Gyro_P = 80;             // Wert : 0-247
229
        EE_Parameter.Gyro_P = 80;             // Wert : 0-247
228
        EE_Parameter.Gyro_I = 150;            // Wert : 0-247
230
        EE_Parameter.Gyro_I = 150;            // Wert : 0-247
229
        EE_Parameter.Gyro_Gier_P = 80;        // Wert : 0-247
231
        EE_Parameter.Gyro_Gier_P = 80;        // Wert : 0-247
230
        EE_Parameter.Gyro_Gier_I = 150;       // Wert : 0-247
232
        EE_Parameter.Gyro_Gier_I = 150;       // Wert : 0-247
231
        EE_Parameter.Gyro_Stability = 6;          // Wert : 1-8
233
        EE_Parameter.Gyro_Stability = 6;          // Wert : 1-8
232
        EE_Parameter.I_Faktor = 32;
234
        EE_Parameter.I_Faktor = 32;
233
        EE_Parameter.AchsKopplung1 = 90;
-
 
234
        EE_Parameter.AchsKopplung2 = 80;
-
 
235
        EE_Parameter.CouplingYawCorrection = 1;
235
        EE_Parameter.CouplingYawCorrection = 1;
236
        EE_Parameter.GyroAccAbgleich = 16;        // 1/k;
236
        EE_Parameter.GyroAccAbgleich = 16;        // 1/k;
237
        EE_Parameter.DynamicStability = 100;
237
        EE_Parameter.DynamicStability = 100;
238
        memcpy(EE_Parameter.Name, "Sport\0", 12);
238
        memcpy(EE_Parameter.Name, "Sport\0", 12);
239
        EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
239
        EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
240
}
240
}
241
 
241
*/
242
 
242
 
243
/***************************************************/
243
/***************************************************/
244
/*    Default Values for parameter set 2           */
244
/*    Default Values for parameter set 1           */
245
/***************************************************/
245
/***************************************************/
246
void ParamSet_DefaultSet2(void) // normal
246
void ParamSet_DefaultSet1(void) // normal
247
{
247
{
248
        CommonDefaults();
248
        CommonDefaults();
249
        EE_Parameter.Stick_P = 10;               // Wert : 1-20
249
        EE_Parameter.Stick_P = 10;               // Wert : 1-20
250
        EE_Parameter.Stick_D = 16;               // Wert : 0-20
250
        EE_Parameter.Stick_D = 16;               // Wert : 0-20
251
        EE_Parameter.Gier_P = 6;                 // Wert : 1-20
251
        EE_Parameter.StickGier_P = 6;                 // Wert : 1-20
252
        EE_Parameter.Gyro_P = 90;                // Wert : 0-247
252
        EE_Parameter.Gyro_P = 90;                // Wert : 0-247
253
        EE_Parameter.Gyro_I = 120;               // Wert : 0-247
253
        EE_Parameter.Gyro_I = 120;               // Wert : 0-247
254
        EE_Parameter.Gyro_Gier_P = 90;           // Wert : 0-247
254
        EE_Parameter.Gyro_Gier_P = 90;           // Wert : 0-247
255
        EE_Parameter.Gyro_Gier_I = 120;          // Wert : 0-247
255
        EE_Parameter.Gyro_Gier_I = 120;          // Wert : 0-247
256
        EE_Parameter.Gyro_Stability = 6;                  // Wert : 1-8
256
        EE_Parameter.Gyro_Stability = 6;                  // Wert : 1-8
257
        EE_Parameter.I_Faktor = 32;
257
        EE_Parameter.I_Faktor = 32;
258
        EE_Parameter.AchsKopplung1 = 90;
-
 
259
        EE_Parameter.AchsKopplung2 = 80;
-
 
260
        EE_Parameter.CouplingYawCorrection = 60;
258
        EE_Parameter.CouplingYawCorrection = 60;
261
        EE_Parameter.GyroAccAbgleich = 32;        // 1/k
259
        EE_Parameter.GyroAccAbgleich = 32;        // 1/k
262
        EE_Parameter.DynamicStability = 75;
260
        EE_Parameter.DynamicStability = 75;
263
        memcpy(EE_Parameter.Name, "Normal\0", 12);
261
        memcpy(EE_Parameter.Name, "Fast\0", 12);
264
        EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
262
        EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
265
}
263
}
266
 
264
 
267
 
265
 
268
/***************************************************/
266
/***************************************************/
269
/*    Default Values for parameter set 3           */
267
/*    Default Values for parameter set 2           */
270
/***************************************************/
268
/***************************************************/
271
void ParamSet_DefaultSet3(void) // beginner
269
void ParamSet_DefaultSet2(void) // beginner
272
{
270
{
273
        CommonDefaults();
271
        CommonDefaults();
274
        EE_Parameter.Stick_P = 8;                // Wert : 1-20
272
        EE_Parameter.Stick_P = 8;                // Wert : 1-20
275
        EE_Parameter.Stick_D = 16;               // Wert : 0-20
273
        EE_Parameter.Stick_D = 16;               // Wert : 0-20
276
        EE_Parameter.Gier_P  = 6;                // Wert : 1-20
274
        EE_Parameter.StickGier_P  = 6;                // Wert : 1-20
277
        EE_Parameter.Gyro_P = 100;               // Wert : 0-247
275
        EE_Parameter.Gyro_P = 100;               // Wert : 0-247
278
        EE_Parameter.Gyro_I = 120;               // Wert : 0-247
276
        EE_Parameter.Gyro_I = 120;               // Wert : 0-247
279
        EE_Parameter.Gyro_Gier_P = 100;          // Wert : 0-247
277
        EE_Parameter.Gyro_Gier_P = 100;          // Wert : 0-247
280
        EE_Parameter.Gyro_Gier_I = 120;          // Wert : 0-247
278
        EE_Parameter.Gyro_Gier_I = 120;          // Wert : 0-247
281
        EE_Parameter.Gyro_Stability = 6;                  // Wert : 1-8
279
        EE_Parameter.Gyro_Stability = 6;                  // Wert : 1-8
282
        EE_Parameter.I_Faktor = 16;
280
        EE_Parameter.I_Faktor = 16;
283
        EE_Parameter.AchsKopplung1 = 90;
-
 
284
        EE_Parameter.AchsKopplung2 = 80;
-
 
285
        EE_Parameter.CouplingYawCorrection = 70;
281
        EE_Parameter.CouplingYawCorrection = 70;
286
        EE_Parameter.GyroAccAbgleich = 32;        // 1/k
282
        EE_Parameter.GyroAccAbgleich = 32;        // 1/k
287
        EE_Parameter.DynamicStability = 70;
283
        EE_Parameter.DynamicStability = 70;
288
        memcpy(EE_Parameter.Name, "Beginner\0", 12);
284
        memcpy(EE_Parameter.Name, "Normal\0", 12);
-
 
285
        EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
-
 
286
}
-
 
287
 
-
 
288
/***************************************************/
-
 
289
/*    Default Values for parameter set 3           */
-
 
290
/***************************************************/
-
 
291
void ParamSet_DefaultSet3(void) // beginner
-
 
292
{
-
 
293
        CommonDefaults();
-
 
294
        EE_Parameter.Stick_P = 6;                // Wert : 1-20
-
 
295
        EE_Parameter.Stick_D = 10;               // Wert : 0-20
-
 
296
        EE_Parameter.StickGier_P  = 4;           // Wert : 1-20
-
 
297
        EE_Parameter.Gyro_P = 100;               // Wert : 0-247
-
 
298
        EE_Parameter.Gyro_I = 120;               // Wert : 0-247
-
 
299
        EE_Parameter.Gyro_Gier_P = 100;          // Wert : 0-247
-
 
300
        EE_Parameter.Gyro_Gier_I = 120;          // Wert : 0-247
-
 
301
        EE_Parameter.Gyro_Stability = 6;              // Wert : 1-8
-
 
302
        EE_Parameter.I_Faktor = 16;
-
 
303
        EE_Parameter.CouplingYawCorrection = 70;
-
 
304
        EE_Parameter.GyroAccAbgleich = 32;        // 1/k
-
 
305
        EE_Parameter.DynamicStability = 70;
-
 
306
        memcpy(EE_Parameter.Name, "Easy\0", 12);
289
        EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
307
        EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
290
}
308
}
-
 
309
 
291
 
310
 
292
/***************************************************/
311
/***************************************************/
293
/*       Read Parameter from EEPROM as byte        */
312
/*       Read Parameter from EEPROM as byte        */
294
/***************************************************/
313
/***************************************************/
295
uint8_t GetParamByte(uint16_t param_id)
314
uint8_t GetParamByte(uint16_t param_id)
296
{
315
{
297
        return eeprom_read_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + param_id));
316
        return eeprom_read_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + param_id));
298
}
317
}
299
 
318
 
300
/***************************************************/
319
/***************************************************/
301
/*       Write Parameter to EEPROM as byte         */
320
/*       Write Parameter to EEPROM as byte         */
302
/***************************************************/
321
/***************************************************/
303
void SetParamByte(uint16_t param_id, uint8_t value)
322
void SetParamByte(uint16_t param_id, uint8_t value)
304
{
323
{
305
        eeprom_write_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + param_id), value);
324
        eeprom_write_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + param_id), value);
306
}
325
}
307
 
326
 
308
/***************************************************/
327
/***************************************************/
309
/*       Read Parameter from EEPROM as word        */
328
/*       Read Parameter from EEPROM as word        */
310
/***************************************************/
329
/***************************************************/
311
uint16_t GetParamWord(uint16_t param_id)
330
uint16_t GetParamWord(uint16_t param_id)
312
{
331
{
313
        return eeprom_read_word((uint16_t *)(EEPROM_ADR_PARAM_BEGIN + param_id));
332
        return eeprom_read_word((uint16_t *)(EEPROM_ADR_PARAM_BEGIN + param_id));
314
}
333
}
315
 
334
 
316
/***************************************************/
335
/***************************************************/
317
/*       Write Parameter to EEPROM as word         */
336
/*       Write Parameter to EEPROM as word         */
318
/***************************************************/
337
/***************************************************/
319
void SetParamWord(uint16_t param_id, uint16_t value)
338
void SetParamWord(uint16_t param_id, uint16_t value)
320
{
339
{
321
        eeprom_write_word((uint16_t*)(EEPROM_ADR_PARAM_BEGIN + param_id), value);
340
        eeprom_write_word((uint16_t*)(EEPROM_ADR_PARAM_BEGIN + param_id), value);
322
}
341
}
323
 
342
 
324
/***************************************************/
343
/***************************************************/
325
/*       Read Parameter Set from EEPROM            */
344
/*       Read Parameter Set from EEPROM            */
326
/***************************************************/
345
/***************************************************/
327
// number [1..5]
346
// number [1..5]
328
uint8_t ParamSet_ReadFromEEProm(uint8_t setnumber)
347
uint8_t ParamSet_ReadFromEEProm(uint8_t setnumber)
329
{
348
{
330
        uint8_t crc;
349
        uint8_t crc;
331
        uint16_t eeaddr;
350
        uint16_t eeaddr;
332
 
351
 
333
        // range the setnumber
352
        // range the setnumber
334
        if((1 > setnumber) || (setnumber > 5)) setnumber = 3;
353
        if((1 > setnumber) || (setnumber > 5)) setnumber = 3;
335
 
354
 
336
        // calculate eeprom addr
355
        // calculate eeprom addr
337
        eeaddr = EEPROM_ADR_PARAMSET + PARAMSET_STRUCT_LEN * (setnumber - 1);
356
        eeaddr = EEPROM_ADR_PARAMSET + PARAMSET_STRUCT_LEN * (setnumber - 1);
338
 
357
 
339
        // calculate checksum from eeprom
358
        // calculate checksum from eeprom
340
        crc = EEProm_Checksum(eeaddr, PARAMSET_STRUCT_LEN - 1);
359
        crc = EEProm_Checksum(eeaddr, PARAMSET_STRUCT_LEN - 1);
341
 
360
 
342
        // check crc
361
        // check crc
343
        if(crc != eeprom_read_byte((uint8_t*)(eeaddr + PARAMSET_STRUCT_LEN - 1))) return 0;
362
        if(crc != eeprom_read_byte((uint8_t*)(eeaddr + PARAMSET_STRUCT_LEN - 1))) return 0;
344
 
363
 
345
        // check revision
364
        // check revision
346
        if(eeprom_read_byte((uint8_t*)(eeaddr)) != EEPARAM_REVISION) return 0;
365
        if(eeprom_read_byte((uint8_t*)(eeaddr)) != EEPARAM_REVISION) return 0;
347
 
366
 
348
        // read paramset from eeprom
367
        // read paramset from eeprom
349
        eeprom_read_block((void *) &EE_Parameter, (void*)(EEPROM_ADR_PARAMSET + PARAMSET_STRUCT_LEN * (setnumber - 1)), PARAMSET_STRUCT_LEN);
368
        eeprom_read_block((void *) &EE_Parameter, (void*)(EEPROM_ADR_PARAMSET + PARAMSET_STRUCT_LEN * (setnumber - 1)), PARAMSET_STRUCT_LEN);
350
        LED_Init();
369
        LED_Init();
351
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__))
370
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__))
352
        LIBFC_HoTT_Clear();
371
        LIBFC_HoTT_Clear();
353
#endif
372
#endif
354
        return 1;
373
        return 1;
355
}
374
}
356
 
375
 
357
/***************************************************/
376
/***************************************************/
358
/*        Write Parameter Set to EEPROM            */
377
/*        Write Parameter Set to EEPROM            */
359
/***************************************************/
378
/***************************************************/
360
// number [1..5]
379
// number [1..5]
361
uint8_t ParamSet_WriteToEEProm(uint8_t setnumber)
380
uint8_t ParamSet_WriteToEEProm(uint8_t setnumber)
362
{
381
{
363
        uint8_t crc;
382
        uint8_t crc;
364
 
383
 
365
        if(EE_Parameter.Revision == EEPARAM_REVISION) // write only the right revision to eeprom
384
        if(EE_Parameter.Revision == EEPARAM_REVISION) // write only the right revision to eeprom
366
        {
385
        {
367
                if(setnumber > 5) setnumber = 5;
386
                if(setnumber > 5) setnumber = 5;
368
                if(setnumber < 1) return 0;
387
                if(setnumber < 1) return 0;
369
        LIBFC_CheckSettings();
388
        LIBFC_CheckSettings();
370
                // update checksum
389
                // update checksum
371
                EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
390
                EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
372
 
391
 
373
                // write paramset to eeprom
392
                // write paramset to eeprom
374
                eeprom_write_block((void *) &EE_Parameter, (void*)(EEPROM_ADR_PARAMSET + PARAMSET_STRUCT_LEN * (setnumber - 1)), PARAMSET_STRUCT_LEN);
393
                eeprom_write_block((void *) &EE_Parameter, (void*)(EEPROM_ADR_PARAMSET + PARAMSET_STRUCT_LEN * (setnumber - 1)), PARAMSET_STRUCT_LEN);
375
 
394
 
376
                // backup channel settings to separate block in eeprom
395
                // backup channel settings to separate block in eeprom
377
                eeprom_write_block( (void*)(EE_Parameter.Kanalbelegung), (void*)(EEPROM_ADR_CHANNELS), sizeof(EE_Parameter.Kanalbelegung));
396
                eeprom_write_block( (void*)(EE_Parameter.Kanalbelegung), (void*)(EEPROM_ADR_CHANNELS), sizeof(EE_Parameter.Kanalbelegung));
378
 
397
 
379
                // write crc of channel block to eeprom
398
                // write crc of channel block to eeprom
380
                crc = RAM_Checksum((uint8_t*)(EE_Parameter.Kanalbelegung), sizeof(EE_Parameter.Kanalbelegung));
399
                crc = RAM_Checksum((uint8_t*)(EE_Parameter.Kanalbelegung), sizeof(EE_Parameter.Kanalbelegung));
381
                eeprom_write_byte((uint8_t*)(EEPROM_ADR_CHANNELS + sizeof(EE_Parameter.Kanalbelegung)), crc);
400
                eeprom_write_byte((uint8_t*)(EEPROM_ADR_CHANNELS + sizeof(EE_Parameter.Kanalbelegung)), crc);
382
 
401
 
383
                // update active settings number
402
                // update active settings number
384
                SetActiveParamSet(setnumber);
403
                SetActiveParamSet(setnumber);
385
                LED_Init();
404
                LED_Init();
386
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__))
405
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__))
387
                LIBFC_HoTT_Clear();
406
                LIBFC_HoTT_Clear();
388
#endif
407
#endif
389
                return 1;
408
                return 1;
390
        }
409
        }
391
        // wrong revision
410
        // wrong revision
392
        return 0;
411
        return 0;
393
}
412
}
394
 
413
 
395
/***************************************************/
414
/***************************************************/
396
/*          Read MixerTable from EEPROM            */
415
/*          Read MixerTable from EEPROM            */
397
/***************************************************/
416
/***************************************************/
398
uint8_t MixerTable_ReadFromEEProm(void)
417
uint8_t MixerTable_ReadFromEEProm(void)
399
{
418
{
400
        uint8_t crc;
419
        uint8_t crc;
401
 
420
 
402
        // calculate checksum in eeprom
421
        // calculate checksum in eeprom
403
        crc = EEProm_Checksum(EEPROM_ADR_MIXERTABLE, sizeof(Mixer) - 1);
422
        crc = EEProm_Checksum(EEPROM_ADR_MIXERTABLE, sizeof(Mixer) - 1);
404
 
423
 
405
        // check crc
424
        // check crc
406
        if( crc != eeprom_read_byte((uint8_t*)(EEPROM_ADR_MIXERTABLE + sizeof(Mixer) - 1)) ) return 0;
425
        if( crc != eeprom_read_byte((uint8_t*)(EEPROM_ADR_MIXERTABLE + sizeof(Mixer) - 1)) ) return 0;
407
 
426
 
408
        // check revision
427
        // check revision
409
        if(eeprom_read_byte((uint8_t*)(EEPROM_ADR_MIXERTABLE)) != EEMIXER_REVISION) return 0;
428
        if(eeprom_read_byte((uint8_t*)(EEPROM_ADR_MIXERTABLE)) != EEMIXER_REVISION) return 0;
410
 
429
 
411
        // read mixer table
430
        // read mixer table
412
        eeprom_read_block((void *) &Mixer, (void*)(EEPROM_ADR_MIXERTABLE), sizeof(Mixer));
431
        eeprom_read_block((void *) &Mixer, (void*)(EEPROM_ADR_MIXERTABLE), sizeof(Mixer));
413
        return 1;
432
        return 1;
414
}
433
}
415
 
434
 
416
/***************************************************/
435
/***************************************************/
417
/*          Write Mixer Table to EEPROM            */
436
/*          Write Mixer Table to EEPROM            */
418
/***************************************************/
437
/***************************************************/
419
uint8_t MixerTable_WriteToEEProm(void)
438
uint8_t MixerTable_WriteToEEProm(void)
420
{
439
{
421
        if(Mixer.Revision == EEMIXER_REVISION)
440
        if(Mixer.Revision == EEMIXER_REVISION)
422
        {
441
        {
423
                // update crc
442
                // update crc
424
                Mixer.crc = RAM_Checksum((uint8_t*)(&Mixer), sizeof(Mixer) - 1);
443
                Mixer.crc = RAM_Checksum((uint8_t*)(&Mixer), sizeof(Mixer) - 1);
425
 
444
 
426
                // write to eeprom
445
                // write to eeprom
427
                eeprom_write_block((void *) &Mixer, (void*)(EEPROM_ADR_MIXERTABLE), sizeof(Mixer));
446
                eeprom_write_block((void *) &Mixer, (void*)(EEPROM_ADR_MIXERTABLE), sizeof(Mixer));
428
                return 1;
447
                return 1;
429
        }
448
        }
430
        else return 0;
449
        else return 0;
431
}
450
}
432
 
451
 
433
/***************************************************/
452
/***************************************************/
434
/*    Default Values for Mixer Table               */
453
/*    Default Values for Mixer Table               */
435
/***************************************************/
454
/***************************************************/
436
void MixerTable_Default(void) // Quadro
455
void MixerTable_Default(void) // Quadro
437
{
456
{
438
        uint8_t i;
457
        uint8_t i;
439
 
458
 
440
        Mixer.Revision = EEMIXER_REVISION;
459
        Mixer.Revision = EEMIXER_REVISION;
441
        // clear mixer table
460
        // clear mixer table
442
        for(i = 0; i < 16; i++)
461
        for(i = 0; i < 16; i++)
443
        {
462
        {
444
                Mixer.Motor[i][MIX_GAS]  = 0;
463
                Mixer.Motor[i][MIX_GAS]  = 0;
445
                Mixer.Motor[i][MIX_NICK] = 0;
464
                Mixer.Motor[i][MIX_NICK] = 0;
446
                Mixer.Motor[i][MIX_ROLL] = 0;
465
                Mixer.Motor[i][MIX_ROLL] = 0;
447
                Mixer.Motor[i][MIX_YAW]  = 0;
466
                Mixer.Motor[i][MIX_YAW]  = 0;
448
        }
467
        }
449
        // default = Quadro
468
        // default = Quadro
450
        Mixer.Motor[0][MIX_GAS] = 64; Mixer.Motor[0][MIX_NICK] = +64; Mixer.Motor[0][MIX_ROLL] =   0; Mixer.Motor[0][MIX_YAW] = +64;
469
        Mixer.Motor[0][MIX_GAS] = 64; Mixer.Motor[0][MIX_NICK] = +64; Mixer.Motor[0][MIX_ROLL] =   0; Mixer.Motor[0][MIX_YAW] = +64;
451
        Mixer.Motor[1][MIX_GAS] = 64; Mixer.Motor[1][MIX_NICK] = -64; Mixer.Motor[1][MIX_ROLL] =   0; Mixer.Motor[1][MIX_YAW] = +64;
470
        Mixer.Motor[1][MIX_GAS] = 64; Mixer.Motor[1][MIX_NICK] = -64; Mixer.Motor[1][MIX_ROLL] =   0; Mixer.Motor[1][MIX_YAW] = +64;
452
        Mixer.Motor[2][MIX_GAS] = 64; Mixer.Motor[2][MIX_NICK] =   0; Mixer.Motor[2][MIX_ROLL] = -64; Mixer.Motor[2][MIX_YAW] = -64;
471
        Mixer.Motor[2][MIX_GAS] = 64; Mixer.Motor[2][MIX_NICK] =   0; Mixer.Motor[2][MIX_ROLL] = -64; Mixer.Motor[2][MIX_YAW] = -64;
453
        Mixer.Motor[3][MIX_GAS] = 64; Mixer.Motor[3][MIX_NICK] =   0; Mixer.Motor[3][MIX_ROLL] = +64; Mixer.Motor[3][MIX_YAW] = -64;
472
        Mixer.Motor[3][MIX_GAS] = 64; Mixer.Motor[3][MIX_NICK] =   0; Mixer.Motor[3][MIX_ROLL] = +64; Mixer.Motor[3][MIX_YAW] = -64;
454
        memcpy(Mixer.Name, "Quadro\0", 7);
473
        memcpy(Mixer.Name, "Quadro\0", 7);
455
        Mixer.crc = Mixer.crc = RAM_Checksum((uint8_t*)(&Mixer), sizeof(Mixer) - 1);
474
        Mixer.crc = Mixer.crc = RAM_Checksum((uint8_t*)(&Mixer), sizeof(Mixer) - 1);
456
}
475
}
457
 
476
 
458
/***************************************************/
477
/***************************************************/
459
/*       Get active parameter set                  */
478
/*       Get active parameter set                  */
460
/***************************************************/
479
/***************************************************/
461
uint8_t GetActiveParamSet(void)
480
uint8_t GetActiveParamSet(void)
462
{
481
{
463
        uint8_t setnumber;
482
        uint8_t setnumber;
464
        setnumber = eeprom_read_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + PID_ACTIVE_SET));
483
        setnumber = eeprom_read_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + PID_ACTIVE_SET));
465
        if(setnumber > 5)
484
        if(setnumber > 5)
466
        {
485
        {
467
                setnumber = 3;
486
                setnumber = 3;
468
                eeprom_write_byte((void*)(EEPROM_ADR_PARAM_BEGIN+PID_ACTIVE_SET), setnumber);
487
                eeprom_write_byte((void*)(EEPROM_ADR_PARAM_BEGIN+PID_ACTIVE_SET), setnumber);
469
        }
488
        }
470
        return(setnumber);
489
        return(setnumber);
471
}
490
}
472
 
491
 
473
/***************************************************/
492
/***************************************************/
474
/*       Set active parameter set                  */
493
/*       Set active parameter set                  */
475
/***************************************************/
494
/***************************************************/
476
void SetActiveParamSet(uint8_t setnumber)
495
void SetActiveParamSet(uint8_t setnumber)
477
{
496
{
478
        if(setnumber > 5) setnumber = 5;
497
        if(setnumber > 5) setnumber = 5;
479
        if(setnumber < 1) setnumber = 1;
498
        if(setnumber < 1) setnumber = 1;
480
        eeprom_write_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + PID_ACTIVE_SET), setnumber);
499
        eeprom_write_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + PID_ACTIVE_SET), setnumber);
481
}
500
}
482
 
501
 
483
/***************************************************/
502
/***************************************************/
484
/*       Set default parameter set                 */
503
/*       Set default parameter set                 */
485
/***************************************************/
504
/***************************************************/
486
void SetDefaultParameter(uint8_t set, uint8_t restore_channels)
505
void SetDefaultParameter(uint8_t set, uint8_t restore_channels)
487
{
506
{
488
 
507
 
489
        if(set > 5) set = 5;
508
        if(set > 5) set = 5;
490
        else if(set < 1) set = 1;
509
        else if(set < 1) set = 1;
491
 
510
 
492
        switch(set)
511
        switch(set)
493
        {
512
        {
494
                case 1:
513
                case 1:
495
                        ParamSet_DefaultSet1(); // Fill ParamSet Structure to default parameter set 1 (Sport)
514
                        ParamSet_DefaultSet1(); // Fill ParamSet Structure to default parameter set 1 (Sport)
496
                        break;
515
                        break;
497
                case 2:
516
                case 2:
498
                        ParamSet_DefaultSet2(); // Kamera
517
                        ParamSet_DefaultSet2(); // Kamera
499
                        break;
518
                        break;
500
                case 3:
519
                case 3:
501
                        ParamSet_DefaultSet3(); // Beginner
520
                        ParamSet_DefaultSet3(); // Beginner
502
                        break;
521
                        break;
503
                default:
522
                default:
504
                        ParamSet_DefaultSet3(); // Beginner
523
                        ParamSet_DefaultSet3(); // Beginner
505
                        break;
524
                        break;
506
        }
525
        }
507
        if(restore_channels)
526
        if(restore_channels)
508
        {
527
        {
509
                uint8_t crc;
528
                uint8_t crc;
510
                // 1st check for a valid channel backup in eeprom
529
                // 1st check for a valid channel backup in eeprom
511
                crc = EEProm_Checksum(EEPROM_ADR_CHANNELS, sizeof(EE_Parameter.Kanalbelegung));
530
                crc = EEProm_Checksum(EEPROM_ADR_CHANNELS, sizeof(EE_Parameter.Kanalbelegung));
512
                if(crc == eeprom_read_byte((uint8_t*)(EEPROM_ADR_CHANNELS + sizeof(EE_Parameter.Kanalbelegung))) )
531
                if(crc == eeprom_read_byte((uint8_t*)(EEPROM_ADR_CHANNELS + sizeof(EE_Parameter.Kanalbelegung))) )
513
                {
532
                {
514
                        eeprom_read_block((void *)EE_Parameter.Kanalbelegung, (void*)(EEPROM_ADR_CHANNELS), sizeof(EE_Parameter.Kanalbelegung));
533
                        eeprom_read_block((void *)EE_Parameter.Kanalbelegung, (void*)(EEPROM_ADR_CHANNELS), sizeof(EE_Parameter.Kanalbelegung));
515
                }
534
                }
516
                else ParamSet_DefaultStickMapping();
535
                else ParamSet_DefaultStickMapping();
517
        }
536
        }
518
        else ParamSet_DefaultStickMapping();
537
        else ParamSet_DefaultStickMapping();
519
        ParamSet_WriteToEEProm(set);
538
        ParamSet_WriteToEEProm(set);
520
}
539
}
521
 
540
 
522
/***************************************************/
541
/***************************************************/
523
/*       Initialize EEPROM Parameter Sets          */
542
/*       Initialize EEPROM Parameter Sets          */
524
/***************************************************/
543
/***************************************************/
525
void ParamSet_Init(void)
544
void ParamSet_Init(void)
526
{
545
{
527
        uint8_t channel_backup  = 0, bad_params = 0, ee_default = 0,i;
546
        uint8_t channel_backup  = 0, bad_params = 0, ee_default = 0,i;
528
 
547
 
529
 
548
 
530
        if(EEPARAM_REVISION != GetParamByte(PID_EE_REVISION) )
549
        if(EEPARAM_REVISION != GetParamByte(PID_EE_REVISION) )
531
        {
550
        {
532
                ee_default = 1; // software update or forced by mktool
551
                ee_default = 1; // software update or forced by mktool
533
        }
552
        }
534
 
553
 
535
 
554
 
536
        // 1st check for a valid channel backup in eeprom
555
        // 1st check for a valid channel backup in eeprom
537
        i = EEProm_Checksum(EEPROM_ADR_CHANNELS, sizeof(EE_Parameter.Kanalbelegung));
556
        i = EEProm_Checksum(EEPROM_ADR_CHANNELS, sizeof(EE_Parameter.Kanalbelegung));
538
        if(i == eeprom_read_byte((uint8_t*)(EEPROM_ADR_CHANNELS + sizeof(EE_Parameter.Kanalbelegung))) ) channel_backup = 1;
557
        if(i == eeprom_read_byte((uint8_t*)(EEPROM_ADR_CHANNELS + sizeof(EE_Parameter.Kanalbelegung))) ) channel_backup = 1;
539
 
558
 
540
 
559
 
541
        // parameter check
560
        // parameter check
542
 
561
 
543
        // check all 5 parameter settings
562
        // check all 5 parameter settings
544
        for (i = 1;i < 6; i++)
563
        for (i = 1;i < 6; i++)
545
        {
564
        {
546
                if(ee_default || !ParamSet_ReadFromEEProm(i)) // could not read paramset from eeprom
565
                if(ee_default || !ParamSet_ReadFromEEProm(i)) // could not read paramset from eeprom
547
                {
566
                {
548
                        bad_params = 1;
567
                        bad_params = 1;
549
                        printf("\n\rGenerating default Parameter Set %d",i);
568
                        printf("\n\rGenerating default Parameter Set %d",i);
550
                        switch(i)
569
                        switch(i)
551
                        {
570
                        {
552
                                case 1:
571
                                case 1:
553
                                        ParamSet_DefaultSet1(); // Fill ParamSet Structure to default parameter set 1 (Sport)
572
                                        ParamSet_DefaultSet1(); // Fill ParamSet Structure to default parameter set 1 (Sport)
554
                                        break;
573
                                        break;
555
                                case 2:
574
                                case 2:
556
                                        ParamSet_DefaultSet2(); // Kamera
575
                                        ParamSet_DefaultSet2(); // Kamera
557
                                        break;
576
                                        break;
558
                                case 3:
577
                                case 3:
559
                                        ParamSet_DefaultSet3(); // Beginner
578
                                        ParamSet_DefaultSet3(); // Beginner
560
                                        break;
579
                                        break;
561
                                default:
580
                                default:
562
                                        ParamSet_DefaultSet3(); // Kamera
581
                                        ParamSet_DefaultSet3(); // Kamera
563
                                        break;
582
                                        break;
564
                        }
583
                        }
565
                        if(channel_backup) // if we have an channel mapping backup in eeprom
584
                        if(channel_backup) // if we have an channel mapping backup in eeprom
566
                        {       // restore it from eeprom
585
                        {       // restore it from eeprom
567
                                eeprom_read_block((void *)EE_Parameter.Kanalbelegung, (void*)(EEPROM_ADR_CHANNELS), sizeof(EE_Parameter.Kanalbelegung));
586
                                eeprom_read_block((void *)EE_Parameter.Kanalbelegung, (void*)(EEPROM_ADR_CHANNELS), sizeof(EE_Parameter.Kanalbelegung));
568
                        }
587
                        }
569
                        else
588
                        else
570
                        {       // use default mapping
589
                        {       // use default mapping
571
                                ParamSet_DefaultStickMapping();
590
                                ParamSet_DefaultStickMapping();
572
                        }
591
                        }
573
                        ParamSet_WriteToEEProm(i);
592
                        ParamSet_WriteToEEProm(i);
574
                }
593
                }
575
        }
594
        }
576
        if(bad_params) // at least one of the parameter settings were invalid
595
        if(bad_params) // at least one of the parameter settings were invalid
577
        {
596
        {
578
                // default-Setting is parameter set 3
597
                // default-Setting is parameter set 3
579
                SetActiveParamSet(3);
598
                SetActiveParamSet(3);
580
        }
599
        }
581
 
600
 
582
 
601
 
583
        // read active parameter set to ParamSet stucture
602
        // read active parameter set to ParamSet stucture
584
        i = GetActiveParamSet();
603
        i = GetActiveParamSet();
585
        ParamSet_ReadFromEEProm(i);
604
        ParamSet_ReadFromEEProm(i);
586
        printf("\n\rUsing Parameter Set %d", i);
605
        printf("\n\rUsing Parameter Set %d", i);
587
 
606
 
588
        // load mixer table
607
        // load mixer table
589
        if(GetParamByte(PID_EE_REVISION) == 0xff || !MixerTable_ReadFromEEProm() )
608
        if(GetParamByte(PID_EE_REVISION) == 0xff || !MixerTable_ReadFromEEProm() )
590
        {
609
        {
591
                printf("\n\rGenerating default Mixer Table");
610
                printf("\n\rGenerating default Mixer Table");
592
                MixerTable_Default(); // Quadro
611
                MixerTable_Default(); // Quadro
593
                MixerTable_WriteToEEProm();
612
                MixerTable_WriteToEEProm();
594
        }
613
        }
595
        if(ee_default)  SetParamByte(PID_EE_REVISION, EEPARAM_REVISION);
614
        if(ee_default)  SetParamByte(PID_EE_REVISION, EEPARAM_REVISION);
596
        // determine motornumber
615
        // determine motornumber
597
        RequiredMotors = 0;
616
        RequiredMotors = 0;
598
        for(i = 0; i < 16; i++)
617
        for(i = 0; i < 16; i++)
599
        {
618
        {
600
                if(Mixer.Motor[i][MIX_GAS] > 0) RequiredMotors++;
619
                if(Mixer.Motor[i][MIX_GAS] > 0) RequiredMotors++;
601
        }
620
        }
602
 
621
 
603
        printf("\n\rMixer-Config: '%s' (%u Motors)",Mixer.Name, RequiredMotors);
622
        printf("\n\rMixer-Config: '%s' (%u Motors)",Mixer.Name, RequiredMotors);
604
        printf("\n\r==============================");
623
        printf("\n\r==============================");
605
}
624
}
606
 
625