Subversion Repositories FlightCtrl

Rev

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

Rev 2402 Rev 2408
1
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
2
// + www.MikroKopter.com
2
// + www.MikroKopter.com
3
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
3
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
4
// + Software Nutzungsbedingungen (english version: see below)
4
// + Software Nutzungsbedingungen (english version: see below)
5
// + der Fa. HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland - nachfolgend Lizenzgeber genannt -
5
// + der Fa. HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland - nachfolgend Lizenzgeber genannt -
6
// + Der Lizenzgeber räumt dem Kunden ein nicht-ausschließliches, zeitlich und räumlich* unbeschränktes Recht ein, die im den
6
// + Der Lizenzgeber räumt dem Kunden ein nicht-ausschließliches, zeitlich und räumlich* unbeschränktes Recht ein, die im den
7
// + Mikrocontroller verwendete Firmware für die Hardware Flight-Ctrl, Navi-Ctrl, BL-Ctrl, MK3Mag & PC-Programm MikroKopter-Tool 
7
// + Mikrocontroller verwendete Firmware für die Hardware Flight-Ctrl, Navi-Ctrl, BL-Ctrl, MK3Mag & PC-Programm MikroKopter-Tool 
8
// + - nachfolgend Software genannt - nur für private Zwecke zu nutzen.
8
// + - nachfolgend Software genannt - nur für private Zwecke zu nutzen.
9
// + Der Einsatz dieser Software ist nur auf oder mit Produkten des Lizenzgebers zulässig.
9
// + Der Einsatz dieser Software ist nur auf oder mit Produkten des Lizenzgebers zulässig.
10
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
10
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
11
// + Die vom Lizenzgeber gelieferte Software ist urheberrechtlich geschützt. Alle Rechte an der Software sowie an sonstigen im
11
// + Die vom Lizenzgeber gelieferte Software ist urheberrechtlich geschützt. Alle Rechte an der Software sowie an sonstigen im
12
// + Rahmen der Vertragsanbahnung und Vertragsdurchführung überlassenen Unterlagen stehen im Verhältnis der Vertragspartner ausschließlich dem Lizenzgeber zu.
12
// + Rahmen der Vertragsanbahnung und Vertragsdurchführung überlassenen Unterlagen stehen im Verhältnis der Vertragspartner ausschließlich dem Lizenzgeber zu.
13
// + Die in der Software enthaltenen Copyright-Vermerke, Markenzeichen, andere Rechtsvorbehalte, Seriennummern sowie
13
// + Die in der Software enthaltenen Copyright-Vermerke, Markenzeichen, andere Rechtsvorbehalte, Seriennummern sowie
14
// + sonstige der Programmidentifikation dienenden Merkmale dürfen vom Kunden nicht verändert oder unkenntlich gemacht werden.
14
// + sonstige der Programmidentifikation dienenden Merkmale dürfen vom Kunden nicht verändert oder unkenntlich gemacht werden.
15
// + Der Kunde trifft angemessene Vorkehrungen für den sicheren Einsatz der Software. Er wird die Software gründlich auf deren
15
// + Der Kunde trifft angemessene Vorkehrungen für den sicheren Einsatz der Software. Er wird die Software gründlich auf deren
16
// + Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt.
16
// + Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt.
17
// + Die Haftung des Lizenzgebers wird - soweit gesetzlich zulässig - begrenzt in Höhe des typischen und vorhersehbaren
17
// + Die Haftung des Lizenzgebers wird - soweit gesetzlich zulässig - begrenzt in Höhe des typischen und vorhersehbaren
18
// + Schadens. Die gesetzliche Haftung bei Personenschäden und nach dem Produkthaftungsgesetz bleibt unberührt. Dem Lizenzgeber steht jedoch der Einwand 
18
// + Schadens. Die gesetzliche Haftung bei Personenschäden und nach dem Produkthaftungsgesetz bleibt unberührt. Dem Lizenzgeber steht jedoch der Einwand 
19
// + des Mitverschuldens offen.
19
// + des Mitverschuldens offen.
20
// + Der Kunde trifft angemessene Vorkehrungen für den Fall, dass die Software ganz oder teilweise nicht ordnungsgemäß arbeitet.
20
// + Der Kunde trifft angemessene Vorkehrungen für den Fall, dass die Software ganz oder teilweise nicht ordnungsgemäß arbeitet.
21
// + Er wird die Software gründlich auf deren Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt.
21
// + Er wird die Software gründlich auf deren Verwendbarkeit zu dem von ihm beabsichtigten Zweck testen, bevor er diese operativ einsetzt.
22
// + Der Kunde wird er seine Daten vor Einsatz der Software nach dem Stand der Technik sichern.
22
// + Der Kunde wird er seine Daten vor Einsatz der Software nach dem Stand der Technik sichern.
23
// + Der Kunde ist darüber unterrichtet, dass der Lizenzgeber seine Daten im zur Vertragsdurchführung erforderlichen Umfang
23
// + Der Kunde ist darüber unterrichtet, dass der Lizenzgeber seine Daten im zur Vertragsdurchführung erforderlichen Umfang
24
// + und auf Grundlage der Datenschutzvorschriften erhebt, speichert, verarbeitet und, sofern notwendig, an Dritte übermittelt.
24
// + und auf Grundlage der Datenschutzvorschriften erhebt, speichert, verarbeitet und, sofern notwendig, an Dritte übermittelt.
25
// + *) Die räumliche Nutzung bezieht sich nur auf den Einsatzort, nicht auf die Reichweite der programmierten Software.
25
// + *) Die räumliche Nutzung bezieht sich nur auf den Einsatzort, nicht auf die Reichweite der programmierten Software.
26
// + #### ENDE DER NUTZUNGSBEDINGUNGEN ####'
26
// + #### ENDE DER NUTZUNGSBEDINGUNGEN ####'
27
// +  Hinweis: Informationen über erweiterte Nutzungsrechte (wie z.B. Nutzung für nicht-private Zwecke) sind auf Anfrage per Email an info(@)hisystems.de verfügbar.
27
// +  Hinweis: Informationen über erweiterte Nutzungsrechte (wie z.B. Nutzung für nicht-private Zwecke) sind auf Anfrage per Email an info(@)hisystems.de verfügbar.
28
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
28
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
29
// + Software LICENSING TERMS
29
// + Software LICENSING TERMS
30
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
30
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
31
// + of HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland, Germany - the Licensor -
31
// + of HiSystems GmbH, Flachsmeerstrasse 2, 26802 Moormerland, Germany - the Licensor -
32
// + The Licensor grants the customer a non-exclusive license to use the microcontroller firmware of the Flight-Ctrl, Navi-Ctrl, BL-Ctrl, and MK3Mag hardware 
32
// + The Licensor grants the customer a non-exclusive license to use the microcontroller firmware of the Flight-Ctrl, Navi-Ctrl, BL-Ctrl, and MK3Mag hardware 
33
// + (the Software) exclusively for private purposes. The License is unrestricted with respect to time and territory*.
33
// + (the Software) exclusively for private purposes. The License is unrestricted with respect to time and territory*.
34
// + The Software may only be used with the Licensor's products.
34
// + The Software may only be used with the Licensor's products.
35
// + The Software provided by the Licensor is protected by copyright. With respect to the relationship between the parties to this
35
// + The Software provided by the Licensor is protected by copyright. With respect to the relationship between the parties to this
36
// + agreement, all rights pertaining to the Software and other documents provided during the preparation and execution of this
36
// + agreement, all rights pertaining to the Software and other documents provided during the preparation and execution of this
37
// + agreement shall be the property of the Licensor.
37
// + agreement shall be the property of the Licensor.
38
// + The information contained in the Software copyright notices, trademarks, other legal reservations, serial numbers and other
38
// + The information contained in the Software copyright notices, trademarks, other legal reservations, serial numbers and other
39
// + features that can be used to identify the program may not be altered or defaced by the customer.
39
// + features that can be used to identify the program may not be altered or defaced by the customer.
40
// + The customer shall be responsible for taking reasonable precautions
40
// + The customer shall be responsible for taking reasonable precautions
41
// + for the safe use of the Software. The customer shall test the Software thoroughly regarding its suitability for the
41
// + for the safe use of the Software. The customer shall test the Software thoroughly regarding its suitability for the
42
// + intended purpose before implementing it for actual operation. The Licensor's liability shall be limited to the extent of typical and
42
// + intended purpose before implementing it for actual operation. The Licensor's liability shall be limited to the extent of typical and
43
// + foreseeable damage to the extent permitted by law, notwithstanding statutory liability for bodily injury and product
43
// + foreseeable damage to the extent permitted by law, notwithstanding statutory liability for bodily injury and product
44
// + liability. However, the Licensor shall be entitled to the defense of contributory negligence.
44
// + liability. However, the Licensor shall be entitled to the defense of contributory negligence.
45
// + The customer will take adequate precautions in the case, that the software is not working properly. The customer will test
45
// + The customer will take adequate precautions in the case, that the software is not working properly. The customer will test
46
// + the software for his purpose before any operational usage. The customer will backup his data before using the software.
46
// + the software for his purpose before any operational usage. The customer will backup his data before using the software.
47
// + The customer understands that the Licensor collects, stores and processes, and, where required, forwards, customer data
47
// + The customer understands that the Licensor collects, stores and processes, and, where required, forwards, customer data
48
// + to third parties to the extent necessary for executing the agreement, subject to applicable data protection and privacy regulations.
48
// + to third parties to the extent necessary for executing the agreement, subject to applicable data protection and privacy regulations.
49
// + *) The territory aspect only refers to the place where the Software is used, not its programmed range.
49
// + *) The territory aspect only refers to the place where the Software is used, not its programmed range.
50
// + #### END OF LICENSING TERMS ####
50
// + #### END OF LICENSING TERMS ####
51
// + Note: For information on license extensions (e.g. commercial use), please contact us at info(@)hisystems.de.
51
// + Note: For information on license extensions (e.g. commercial use), please contact us at info(@)hisystems.de.
52
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
52
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
53
 
53
 
54
 
54
 
55
#ifndef EEMEM
55
#ifndef EEMEM
56
#define EEMEM __attribute__ ((section (".eeprom")))
56
#define EEMEM __attribute__ ((section (".eeprom")))
57
#endif
57
#endif
58
 
58
 
59
 
59
 
60
#include <avr/eeprom.h>
60
#include <avr/eeprom.h>
61
#include <string.h>
61
#include <string.h>
62
#include "eeprom.h"
62
#include "eeprom.h"
63
#include "uart.h"
63
#include "uart.h"
64
#include "led.h"
64
#include "led.h"
65
#include "main.h"
65
#include "main.h"
66
#include "fc.h"
66
#include "fc.h"
67
#include "twimaster.h"
67
#include "twimaster.h"
68
 
68
 
69
paramset_t              EE_Parameter;
69
paramset_t              EE_Parameter;
70
MixerTable_t    Mixer;
70
MixerTable_t    Mixer;
71
uint8_t RequiredMotors;
71
uint8_t RequiredMotors;
72
 
72
 
73
 
73
 
74
uint8_t RAM_Checksum(uint8_t* pBuffer, uint16_t len)
74
uint8_t RAM_Checksum(uint8_t* pBuffer, uint16_t len)
75
{
75
{
76
        uint8_t crc = 0xAA;
76
        uint8_t crc = 0xAA;
77
        uint16_t i;
77
        uint16_t i;
78
 
78
 
79
        for(i=0; i<len; i++)
79
        for(i=0; i<len; i++)
80
        {
80
        {
81
                crc += pBuffer[i];
81
                crc += pBuffer[i];
82
        }
82
        }
83
        return crc;
83
        return crc;
84
}
84
}
85
 
85
 
86
uint8_t EEProm_Checksum(uint16_t EEAddr, uint16_t len)
86
uint8_t EEProm_Checksum(uint16_t EEAddr, uint16_t len)
87
{
87
{
88
        uint8_t crc = 0xAA;
88
        uint8_t crc = 0xAA;
89
        uint16_t off;
89
        uint16_t off;
90
 
90
 
91
        for(off=0; off<len; off++)
91
        for(off=0; off<len; off++)
92
        {
92
        {
93
                crc += eeprom_read_byte((uint8_t*)(EEAddr + off));;
93
                crc += eeprom_read_byte((uint8_t*)(EEAddr + off));;
94
        }
94
        }
95
        return crc;
95
        return crc;
96
}
96
}
97
 
97
 
98
void ParamSet_DefaultStickMapping(void)
98
void ParamSet_DefaultStickMapping(void)
99
{
99
{
100
        EE_Parameter.Kanalbelegung[K_GAS]   = 1;
100
        EE_Parameter.Kanalbelegung[K_GAS]   = 1;
101
        EE_Parameter.Kanalbelegung[K_ROLL]  = 2;
101
        EE_Parameter.Kanalbelegung[K_ROLL]  = 2;
102
        EE_Parameter.Kanalbelegung[K_NICK]  = 3;
102
        EE_Parameter.Kanalbelegung[K_NICK]  = 3;
103
        EE_Parameter.Kanalbelegung[K_GIER]  = 4;
103
        EE_Parameter.Kanalbelegung[K_GIER]  = 4;
104
        EE_Parameter.Kanalbelegung[K_POTI1] = 5;
104
        EE_Parameter.Kanalbelegung[K_POTI1] = 5;
105
        EE_Parameter.Kanalbelegung[K_POTI2] = 6;
105
        EE_Parameter.Kanalbelegung[K_POTI2] = 6;
106
        EE_Parameter.Kanalbelegung[K_POTI3] = 7;
106
        EE_Parameter.Kanalbelegung[K_POTI3] = 7;
107
        EE_Parameter.Kanalbelegung[K_POTI4] = 8;
107
        EE_Parameter.Kanalbelegung[K_POTI4] = 8;
108
        EE_Parameter.Kanalbelegung[K_POTI5] = 9;
108
        EE_Parameter.Kanalbelegung[K_POTI5] = 9;
109
        EE_Parameter.Kanalbelegung[K_POTI6] = 10;
109
        EE_Parameter.Kanalbelegung[K_POTI6] = 10;
110
        EE_Parameter.Kanalbelegung[K_POTI7] = 11;
110
        EE_Parameter.Kanalbelegung[K_POTI7] = 11;
111
        EE_Parameter.Kanalbelegung[K_POTI8] = 12;
111
        EE_Parameter.Kanalbelegung[K_POTI8] = 12;
112
}
112
}
113
 
113
 
114
 
114
 
115
/***************************************************/
115
/***************************************************/
116
/*    Default Values for parameter set 1           */
116
/*    Default Values for parameter set 1           */
117
/***************************************************/
117
/***************************************************/
118
void CommonDefaults(void)
118
void CommonDefaults(void)
119
{
119
{
120
        EE_Parameter.Revision = EEPARAM_REVISION;
120
        EE_Parameter.Revision = EEPARAM_REVISION;
121
        memset(EE_Parameter.Name,0,12); // delete name
121
        memset(EE_Parameter.Name,0,12); // delete name
122
        if(PlatinenVersion >= 20)
122
        if(PlatinenVersion >= 20)
123
        {
123
        {
124
                EE_Parameter.Gyro_D = 10;
124
                EE_Parameter.Gyro_D = 10;
125
                EE_Parameter.Driftkomp = 0;
125
                EE_Parameter.Driftkomp = 0;
126
                EE_Parameter.GyroAccFaktor = 27;
126
                EE_Parameter.GyroAccFaktor = 27;
127
                EE_Parameter.WinkelUmschlagNick = 78;
127
                EE_Parameter.WinkelUmschlagNick = 78;
128
                EE_Parameter.WinkelUmschlagRoll = 78;
128
                EE_Parameter.WinkelUmschlagRoll = 78;
129
        }
129
        }
130
        else
130
        else
131
        {
131
        {
132
                EE_Parameter.Gyro_D = 3;
132
                EE_Parameter.Gyro_D = 3;
133
                EE_Parameter.Driftkomp = 32;
133
                EE_Parameter.Driftkomp = 32;
134
                EE_Parameter.GyroAccFaktor = 30;
134
                EE_Parameter.GyroAccFaktor = 30;
135
                EE_Parameter.WinkelUmschlagNick = 85;
135
                EE_Parameter.WinkelUmschlagNick = 85;
136
                EE_Parameter.WinkelUmschlagRoll = 85;
136
                EE_Parameter.WinkelUmschlagRoll = 85;
137
        }
137
        }
138
        EE_Parameter.GyroAccAbgleich = 32;        // 1/k
138
        EE_Parameter.GyroAccAbgleich = 32;        // 1/k
139
        EE_Parameter.BitConfig = 0;              // Looping usw.
139
        EE_Parameter.BitConfig = 0;              // Looping usw.
140
        EE_Parameter.GlobalConfig = CFG_ACHSENKOPPLUNG_AKTIV | CFG_KOMPASS_AKTIV | CFG_GPS_AKTIV | CFG_HOEHEN_SCHALTER;
140
        EE_Parameter.GlobalConfig = CFG_ACHSENKOPPLUNG_AKTIV | CFG_KOMPASS_AKTIV | CFG_GPS_AKTIV | CFG_HOEHEN_SCHALTER;
141
        EE_Parameter.ExtraConfig = CFG_GPS_AID | CFG2_VARIO_BEEP | CFG_LEARNABLE_CAREFREE | CFG_NO_RCOFF_BEEPING;
141
        EE_Parameter.ExtraConfig = CFG_GPS_AID | CFG2_VARIO_BEEP | CFG_LEARNABLE_CAREFREE | CFG_NO_RCOFF_BEEPING;
142
        EE_Parameter.GlobalConfig3 = CFG3_SPEAK_ALL | CFG3_NO_GPSFIX_NO_START;//
142
        EE_Parameter.GlobalConfig3 = CFG3_SPEAK_ALL | CFG3_NO_GPSFIX_NO_START;//
143
        EE_Parameter.Receiver = RECEIVER_HOTT;
143
        EE_Parameter.Receiver = RECEIVER_HOTT;
144
        EE_Parameter.MotorSafetySwitch = 0;
144
        EE_Parameter.MotorSafetySwitch = 0;
145
        EE_Parameter.ExternalControl = 0;
145
        EE_Parameter.ExternalControl = 0;
146
 
146
 
147
        EE_Parameter.Gas_Min = 8;             // Wert : 0-32
147
        EE_Parameter.Gas_Min = 8;             // Wert : 0-32
148
        EE_Parameter.Gas_Max = 230;           // Wert : 33-247
148
        EE_Parameter.Gas_Max = 230;           // Wert : 33-247
149
        EE_Parameter.KompassWirkung = 64;    // Wert : 0-247
149
        EE_Parameter.KompassWirkung = 64;    // Wert : 0-247
150
 
150
 
151
        EE_Parameter.HoeheChannel = 5;         // Wert : 0-32
151
        EE_Parameter.HoeheChannel = 5;         // Wert : 0-32
152
        EE_Parameter.Hoehe_MinGas = 30;
152
        EE_Parameter.Hoehe_MinGas = 30;
153
 
153
 
154
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__))
154
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__))
155
        if(ACC_AltitudeControl)
155
        if(ACC_AltitudeControl)
156
        {
156
        {
157
                EE_Parameter.Hoehe_P      = 20;          // Wert : 0-32
157
                EE_Parameter.Hoehe_P      = 20;          // Wert : 0-32
158
                EE_Parameter.Luftdruck_D  = 40;          // Wert : 0-247
158
                EE_Parameter.Luftdruck_D  = 40;          // Wert : 0-247
159
                EE_Parameter.Hoehe_ACC_Wirkung = 30;     // Wert : 0-247
159
                EE_Parameter.Hoehe_ACC_Wirkung = 30;     // Wert : 0-247
160
                EE_Parameter.Hoehe_HoverBand = 1;         // Wert : 0-247
160
                EE_Parameter.Hoehe_HoverBand = 1;         // Wert : 0-247
161
                EE_Parameter.Hoehe_GPS_Z = 0;           // Wert : 0-247
161
                EE_Parameter.Hoehe_GPS_Z = 0;           // Wert : 0-247
162
                EE_Parameter.Hoehe_StickNeutralPoint = 127;// Wert : 0-247 (0 = Hover-Estimation)
162
                EE_Parameter.Hoehe_StickNeutralPoint = 127;// Wert : 0-247 (0 = Hover-Estimation)
163
                EE_Parameter.FailSafeTime = 30;                   // 0 = off
163
                EE_Parameter.FailSafeTime = 30;                   // 0 = off
164
        }
164
        }
165
        else
165
        else
166
#endif
166
#endif
167
        {
167
        {
168
                EE_Parameter.Hoehe_P      = 15;          // Wert : 0-32
168
                EE_Parameter.Hoehe_P      = 15;          // Wert : 0-32
169
                EE_Parameter.Luftdruck_D  = 30;          // Wert : 0-247
169
                EE_Parameter.Luftdruck_D  = 30;          // Wert : 0-247
170
                EE_Parameter.Hoehe_ACC_Wirkung = 0;     // Wert : 0-247
170
                EE_Parameter.Hoehe_ACC_Wirkung = 0;     // Wert : 0-247
171
                EE_Parameter.Hoehe_HoverBand = 8;         // Wert : 0-247
171
                EE_Parameter.Hoehe_HoverBand = 8;         // Wert : 0-247
172
                EE_Parameter.Hoehe_GPS_Z = 20;           // Wert : 0-247
172
                EE_Parameter.Hoehe_GPS_Z = 20;           // Wert : 0-247
173
                EE_Parameter.Hoehe_StickNeutralPoint = 0;// Wert : 0-247 (0 = Hover-Estimation)
173
                EE_Parameter.Hoehe_StickNeutralPoint = 0;// Wert : 0-247 (0 = Hover-Estimation)
174
                EE_Parameter.FailSafeTime = 0;            // 0 = off
174
                EE_Parameter.FailSafeTime = 0;            // 0 = off
175
        }
175
        }
176
       
176
       
177
        EE_Parameter.Hoehe_Verstaerkung = 15;    // Wert : 0-50 (15 -> ca. +/- 5m/sek bei Stick-Voll-Ausschlag)
177
        EE_Parameter.Hoehe_Verstaerkung = 15;    // Wert : 0-50 (15 -> ca. +/- 5m/sek bei Stick-Voll-Ausschlag)
178
        EE_Parameter.StartLandChannel = 0;  
178
        EE_Parameter.StartLandChannel = 0;  
179
        EE_Parameter.LandingSpeed = 12;  
179
        EE_Parameter.LandingSpeed = 12;  
180
 
180
 
181
        EE_Parameter.UserParam1 =   0;           // zur freien Verwendung
181
        EE_Parameter.UserParam1 =   0;           // zur freien Verwendung
182
        EE_Parameter.UserParam2 =   0;           // zur freien Verwendung
182
        EE_Parameter.UserParam2 =   0;           // zur freien Verwendung
183
        EE_Parameter.UserParam3 =   0;           // zur freien Verwendung
183
        EE_Parameter.UserParam3 =   0;           // zur freien Verwendung
184
        EE_Parameter.UserParam4 =   0;           // zur freien Verwendung
184
        EE_Parameter.UserParam4 =   0;           // zur freien Verwendung
185
        EE_Parameter.UserParam5 =   0;           // zur freien Verwendung
185
        EE_Parameter.UserParam5 =   0;           // zur freien Verwendung
186
        EE_Parameter.UserParam6 =   0;           // zur freien Verwendung
186
        EE_Parameter.UserParam6 =   0;           // zur freien Verwendung
187
        EE_Parameter.UserParam7 = 0;             // zur freien Verwendung
187
        EE_Parameter.UserParam7 = 0;             // zur freien Verwendung
188
        EE_Parameter.UserParam8 = 0;             // zur freien Verwendung
188
        EE_Parameter.UserParam8 = 0;             // zur freien Verwendung
189
 
189
 
190
        EE_Parameter.ServoNickControl = 128;     // Wert : 0-247     // Stellung des Servos
190
        EE_Parameter.ServoNickControl = 128;     // Wert : 0-247     // Stellung des Servos
191
        EE_Parameter.ServoNickComp = 50;         // Wert : 0-247     // Einfluss Gyro/Servo
191
        EE_Parameter.ServoNickComp = 50;         // Wert : 0-247     // Einfluss Gyro/Servo
192
        EE_Parameter.ServoCompInvert = 2;        // Wert : 0-247     // Richtung Einfluss Gyro/Servo
192
        EE_Parameter.ServoCompInvert = 2;        // Wert : 0-247     // Richtung Einfluss Gyro/Servo
193
        EE_Parameter.ServoNickMin = 24;          // Wert : 0-247     // Anschlag
193
        EE_Parameter.ServoNickMin = 24;          // Wert : 0-247     // Anschlag
194
        EE_Parameter.ServoNickMax = 230;         // Wert : 0-247     // Anschlag
194
        EE_Parameter.ServoNickMax = 230;         // Wert : 0-247     // Anschlag
195
        EE_Parameter.ServoNickRefresh = 3;
195
        EE_Parameter.ServoNickRefresh = 3;
196
        EE_Parameter.Servo3 = 125;
196
        EE_Parameter.Servo3 = 125;
197
        EE_Parameter.Servo4 = 125;
197
        EE_Parameter.Servo4 = 125;
198
        EE_Parameter.Servo5 = 125;
198
        EE_Parameter.Servo5 = 125;
199
        EE_Parameter.ServoRollControl = 128;     // Wert : 0-247     // Stellung des Servos
199
        EE_Parameter.ServoRollControl = 128;     // Wert : 0-247     // Stellung des Servos
200
        EE_Parameter.ServoRollComp = 85;         // Wert : 0-247     // Einfluss Gyro/Servo
200
        EE_Parameter.ServoRollComp = 85;         // Wert : 0-247     // Einfluss Gyro/Servo
201
        EE_Parameter.ServoRollMin = 70;          // Wert : 0-247     // Anschlag
201
        EE_Parameter.ServoRollMin = 70;          // Wert : 0-247     // Anschlag
202
        EE_Parameter.ServoRollMax = 220;         // Wert : 0-247     // Anschlag
202
        EE_Parameter.ServoRollMax = 220;         // Wert : 0-247     // Anschlag
203
        EE_Parameter.ServoManualControlSpeed = 60;
203
        EE_Parameter.ServoManualControlSpeed = 60;
204
        EE_Parameter.CamOrientation = 0;         // Wert : 0-24 -> 0-360 -> 15° steps
204
        EE_Parameter.CamOrientation = 0;         // Wert : 0-24 -> 0-360 -> 15° steps
205
 
205
 
206
        EE_Parameter.J16Bitmask = 0xAA;
206
        EE_Parameter.J16Bitmask = 0xAA;
207
        EE_Parameter.J17Bitmask = 0xCC;
207
        EE_Parameter.J17Bitmask = 0xCC;
208
        EE_Parameter.WARN_J16_Bitmask = 0x00;
208
        EE_Parameter.WARN_J16_Bitmask = 0x00;
209
        EE_Parameter.WARN_J17_Bitmask = 0xAA;
209
        EE_Parameter.WARN_J17_Bitmask = 0xAA;
210
        EE_Parameter.J16Timing = 40;
210
        EE_Parameter.J16Timing = 40;
211
        EE_Parameter.J17Timing = 40;
211
        EE_Parameter.J17Timing = 40;
212
    EE_Parameter.NaviOut1Parameter = 0;       // Photo release in meter
212
    EE_Parameter.NaviOut1Parameter = 0;       // Photo release in meter
213
        EE_Parameter.LoopGasLimit = 50;
213
        EE_Parameter.LoopGasLimit = 50;
214
        EE_Parameter.LoopThreshold = 90;         // Wert: 0-247  Schwelle für Stickausschlag
214
        EE_Parameter.LoopThreshold = 90;         // Wert: 0-247  Schwelle für Stickausschlag
215
        EE_Parameter.LoopHysterese = 50;
215
        EE_Parameter.LoopHysterese = 50;
216
 
216
 
217
        EE_Parameter.NaviGpsModeChannel = 6; // Kanal 6
217
        EE_Parameter.NaviGpsModeChannel = 6; // Kanal 6
218
        EE_Parameter.NaviGpsGain = 100;
218
        EE_Parameter.NaviGpsGain = 100;
219
        EE_Parameter.NaviGpsP =  100;
219
        EE_Parameter.NaviGpsP =  100;
220
        EE_Parameter.NaviGpsI =   90;
220
        EE_Parameter.NaviGpsI =   90;
221
        EE_Parameter.NaviGpsD =  120;
221
        EE_Parameter.NaviGpsD =  120;
222
        EE_Parameter.NaviGpsA =   40;
222
        EE_Parameter.NaviGpsA =   40;
223
        EE_Parameter.NaviGpsPLimit = 75;
223
        EE_Parameter.NaviGpsPLimit = 75;
224
        EE_Parameter.NaviGpsILimit = 85;
224
        EE_Parameter.NaviGpsILimit = 85;
225
        EE_Parameter.NaviGpsDLimit = 75;
225
        EE_Parameter.NaviGpsDLimit = 75;
226
        EE_Parameter.NaviGpsMinSat = 6;
226
        EE_Parameter.NaviGpsMinSat = 6;
227
        EE_Parameter.NaviStickThreshold = 8;
227
        EE_Parameter.NaviStickThreshold = 8;
228
        EE_Parameter.NaviWindCorrection = 50;
228
        EE_Parameter.NaviWindCorrection = 50;
229
        EE_Parameter.NaviAccCompensation = 42;
229
        EE_Parameter.NaviAccCompensation = 42;
230
        EE_Parameter.NaviOperatingRadius = 245;
230
        EE_Parameter.NaviOperatingRadius = 245;
231
        EE_Parameter.NaviAngleLimitation = 140;
231
        EE_Parameter.NaviAngleLimitation = 140;
232
        EE_Parameter.NaviPH_LoginTime = 2;
232
        EE_Parameter.NaviPH_LoginTime = 2;
233
        EE_Parameter.OrientationAngle = 0;
233
        EE_Parameter.OrientationAngle = 0;
234
        EE_Parameter.CareFreeChannel = 0;
234
        EE_Parameter.CareFreeChannel = 0;
235
        EE_Parameter.UnterspannungsWarnung = 33; // Wert : 0-247 ( Automatische Zellenerkennung bei < 50)
-
 
236
        EE_Parameter.NotGas = 65;                // Wert : 0-247     // Gaswert bei Empangsverlust (ggf. in Prozent)
235
        EE_Parameter.NotGas = 65;                // Wert : 0-247     // Gaswert bei Empangsverlust (ggf. in Prozent)
237
        EE_Parameter.NotGasZeit = 90;            // Wert : 0-247     // Zeit bis auf NotGas geschaltet wird, wg. Rx-Problemen
236
        EE_Parameter.NotGasZeit = 90;            // Wert : 0-247     // Zeit bis auf NotGas geschaltet wird, wg. Rx-Problemen
238
        EE_Parameter.MotorSmooth = 0;          
237
        EE_Parameter.MotorSmooth = 0;          
239
        EE_Parameter.ComingHomeAltitude = 0;      // 0 = don't change 
238
        EE_Parameter.ComingHomeAltitude = 0;      // 0 = don't change 
240
        EE_Parameter.MaxAltitude = 150;           // 0 = off
239
        EE_Parameter.MaxAltitude = 150;           // 0 = off
241
        EE_Parameter.AchsKopplung1 = 125;
240
        EE_Parameter.AchsKopplung1 = 125;
242
        EE_Parameter.AchsKopplung2 = 52;
241
        EE_Parameter.AchsKopplung2 = 52;
243
        EE_Parameter.FailsafeChannel = 0;
242
        EE_Parameter.FailsafeChannel = 0;
244
        EE_Parameter.ServoFilterNick = 0;
243
        EE_Parameter.ServoFilterNick = 0;
245
        EE_Parameter.ServoFilterRoll = 0;
244
        EE_Parameter.ServoFilterRoll = 0;
246
        EE_Parameter.CompassOffset = 0;
245
        EE_Parameter.CompassOffset = 0;
-
 
246
 
-
 
247
        EE_Parameter.UnterspannungsWarnung      = 33; // Wert : 0-247 ( Automatische Zellenerkennung bei < 50)
-
 
248
        EE_Parameter.ComingHomeVoltage          = 32;
247
        EE_Parameter.AutoLandingVoltage = 31;
249
        EE_Parameter.AutoLandingVoltage         = 31;
248
}
250
}
249
/*
251
/*
250
void ParamSet_DefaultSet1(void) // sport
252
void ParamSet_DefaultSet1(void) // sport
251
{
253
{
252
        CommonDefaults();
254
        CommonDefaults();
253
        EE_Parameter.Stick_P = 14;            // Wert : 1-20
255
        EE_Parameter.Stick_P = 14;            // Wert : 1-20
254
        EE_Parameter.Stick_D = 16;            // Wert : 0-20
256
        EE_Parameter.Stick_D = 16;            // Wert : 0-20
255
        EE_Parameter.StickGier_P = 12;             // Wert : 1-20
257
        EE_Parameter.StickGier_P = 12;             // Wert : 1-20
256
        EE_Parameter.Gyro_P = 80;             // Wert : 0-247
258
        EE_Parameter.Gyro_P = 80;             // Wert : 0-247
257
        EE_Parameter.Gyro_I = 150;            // Wert : 0-247
259
        EE_Parameter.Gyro_I = 150;            // Wert : 0-247
258
        EE_Parameter.Gyro_Gier_P = 80;        // Wert : 0-247
260
        EE_Parameter.Gyro_Gier_P = 80;        // Wert : 0-247
259
        EE_Parameter.Gyro_Gier_I = 150;       // Wert : 0-247
261
        EE_Parameter.Gyro_Gier_I = 150;       // Wert : 0-247
260
        EE_Parameter.Gyro_Stability = 6;          // Wert : 1-8
262
        EE_Parameter.Gyro_Stability = 6;          // Wert : 1-8
261
        EE_Parameter.I_Faktor = 32;
263
        EE_Parameter.I_Faktor = 32;
262
        EE_Parameter.CouplingYawCorrection = 1;
264
        EE_Parameter.CouplingYawCorrection = 1;
263
        EE_Parameter.GyroAccAbgleich = 16;        // 1/k;
265
        EE_Parameter.GyroAccAbgleich = 16;        // 1/k;
264
        EE_Parameter.DynamicStability = 100;
266
        EE_Parameter.DynamicStability = 100;
265
        memcpy(EE_Parameter.Name, "Sport\0", 12);
267
        memcpy(EE_Parameter.Name, "Sport\0", 12);
266
        EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
268
        EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
267
}
269
}
268
*/
270
*/
269
 
271
 
270
/***************************************************/
272
/***************************************************/
271
/*    Default Values for parameter set 1           */
273
/*    Default Values for parameter set 1           */
272
/***************************************************/
274
/***************************************************/
273
void ParamSet_DefaultSet1(void) // normal
275
void ParamSet_DefaultSet1(void) // normal
274
{
276
{
275
        CommonDefaults();
277
        CommonDefaults();
276
        EE_Parameter.Stick_P = 10;               // Wert : 1-20
278
        EE_Parameter.Stick_P = 10;               // Wert : 1-20
277
        EE_Parameter.Stick_D = 16;               // Wert : 0-20
279
        EE_Parameter.Stick_D = 16;               // Wert : 0-20
278
        EE_Parameter.StickGier_P = 6;                 // Wert : 1-20
280
        EE_Parameter.StickGier_P = 6;                 // Wert : 1-20
279
        EE_Parameter.Gyro_P = 90;                // Wert : 0-247
281
        EE_Parameter.Gyro_P = 90;                // Wert : 0-247
280
        EE_Parameter.Gyro_I = 120;               // Wert : 0-247
282
        EE_Parameter.Gyro_I = 120;               // Wert : 0-247
281
        EE_Parameter.Gyro_Gier_P = 90;           // Wert : 0-247
283
        EE_Parameter.Gyro_Gier_P = 90;           // Wert : 0-247
282
        EE_Parameter.Gyro_Gier_I = 120;          // Wert : 0-247
284
        EE_Parameter.Gyro_Gier_I = 120;          // Wert : 0-247
283
        EE_Parameter.Gyro_Stability = 6;                  // Wert : 1-8
285
        EE_Parameter.Gyro_Stability = 6;                  // Wert : 1-8
284
        EE_Parameter.I_Faktor = 32;
286
        EE_Parameter.I_Faktor = 32;
285
        EE_Parameter.CouplingYawCorrection = 60;
287
        EE_Parameter.CouplingYawCorrection = 60;
286
        EE_Parameter.DynamicStability = 75;
288
        EE_Parameter.DynamicStability = 75;
287
        memcpy(EE_Parameter.Name, "Fast",4);
289
        memcpy(EE_Parameter.Name, "Fast",4);
288
        EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
290
        EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
289
}
291
}
290
 
292
 
291
 
293
 
292
/***************************************************/
294
/***************************************************/
293
/*    Default Values for parameter set 2           */
295
/*    Default Values for parameter set 2           */
294
/***************************************************/
296
/***************************************************/
295
void ParamSet_DefaultSet2(void) // Agil
297
void ParamSet_DefaultSet2(void) // Agil
296
{
298
{
297
        CommonDefaults();
299
        CommonDefaults();
298
        EE_Parameter.Stick_P = 8;                // Wert : 1-20
300
        EE_Parameter.Stick_P = 8;                // Wert : 1-20
299
        EE_Parameter.Stick_D = 16;               // Wert : 0-20
301
        EE_Parameter.Stick_D = 16;               // Wert : 0-20
300
        EE_Parameter.StickGier_P  = 6;                // Wert : 1-20
302
        EE_Parameter.StickGier_P  = 6;                // Wert : 1-20
301
        EE_Parameter.Gyro_P = 100;               // Wert : 0-247
303
        EE_Parameter.Gyro_P = 100;               // Wert : 0-247
302
        EE_Parameter.Gyro_I = 120;               // Wert : 0-247
304
        EE_Parameter.Gyro_I = 120;               // Wert : 0-247
303
        EE_Parameter.Gyro_Gier_P = 100;          // Wert : 0-247
305
        EE_Parameter.Gyro_Gier_P = 100;          // Wert : 0-247
304
        EE_Parameter.Gyro_Gier_I = 120;          // Wert : 0-247
306
        EE_Parameter.Gyro_Gier_I = 120;          // Wert : 0-247
305
        EE_Parameter.Gyro_Stability = 6;                  // Wert : 1-8
307
        EE_Parameter.Gyro_Stability = 6;                  // Wert : 1-8
306
        EE_Parameter.I_Faktor = 16;
308
        EE_Parameter.I_Faktor = 16;
307
        EE_Parameter.CouplingYawCorrection = 70;
309
        EE_Parameter.CouplingYawCorrection = 70;
308
        EE_Parameter.DynamicStability = 70;
310
        EE_Parameter.DynamicStability = 70;
309
        memcpy(EE_Parameter.Name, "Agile",5);
311
        memcpy(EE_Parameter.Name, "Agile",5);
310
        EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
312
        EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
311
}
313
}
312
 
314
 
313
/***************************************************/
315
/***************************************************/
314
/*    Default Values for parameter set 3           */
316
/*    Default Values for parameter set 3           */
315
/***************************************************/
317
/***************************************************/
316
void ParamSet_DefaultSet3(void) // Easy
318
void ParamSet_DefaultSet3(void) // Easy
317
{
319
{
318
        CommonDefaults();
320
        CommonDefaults();
319
        EE_Parameter.Stick_P = 6;                // Wert : 1-20
321
        EE_Parameter.Stick_P = 6;                // Wert : 1-20
320
        EE_Parameter.Stick_D = 10;               // Wert : 0-20
322
        EE_Parameter.Stick_D = 10;               // Wert : 0-20
321
        EE_Parameter.StickGier_P  = 4;           // Wert : 1-20
323
        EE_Parameter.StickGier_P  = 4;           // Wert : 1-20
322
        EE_Parameter.Gyro_P = 100;               // Wert : 0-247
324
        EE_Parameter.Gyro_P = 100;               // Wert : 0-247
323
        EE_Parameter.Gyro_I = 120;               // Wert : 0-247
325
        EE_Parameter.Gyro_I = 120;               // Wert : 0-247
324
        EE_Parameter.Gyro_Gier_P = 100;          // Wert : 0-247
326
        EE_Parameter.Gyro_Gier_P = 100;          // Wert : 0-247
325
        EE_Parameter.Gyro_Gier_I = 120;          // Wert : 0-247
327
        EE_Parameter.Gyro_Gier_I = 120;          // Wert : 0-247
326
        EE_Parameter.Gyro_Stability = 6;              // Wert : 1-8
328
        EE_Parameter.Gyro_Stability = 6;              // Wert : 1-8
327
        EE_Parameter.I_Faktor = 16;
329
        EE_Parameter.I_Faktor = 16;
328
        EE_Parameter.CouplingYawCorrection = 70;
330
        EE_Parameter.CouplingYawCorrection = 70;
329
        EE_Parameter.DynamicStability = 70;
331
        EE_Parameter.DynamicStability = 70;
330
        memcpy(EE_Parameter.Name, "Easy", 4);
332
        memcpy(EE_Parameter.Name, "Easy", 4);
331
        EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
333
        EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
332
}
334
}
333
 
335
 
334
 
336
 
335
/***************************************************/
337
/***************************************************/
336
/*       Read Parameter from EEPROM as byte        */
338
/*       Read Parameter from EEPROM as byte        */
337
/***************************************************/
339
/***************************************************/
338
uint8_t GetParamByte(uint16_t param_id)
340
uint8_t GetParamByte(uint16_t param_id)
339
{
341
{
340
        return eeprom_read_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + param_id));
342
        return eeprom_read_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + param_id));
341
}
343
}
342
 
344
 
343
/***************************************************/
345
/***************************************************/
344
/*       Write Parameter to EEPROM as byte         */
346
/*       Write Parameter to EEPROM as byte         */
345
/***************************************************/
347
/***************************************************/
346
void SetParamByte(uint16_t param_id, uint8_t value)
348
void SetParamByte(uint16_t param_id, uint8_t value)
347
{
349
{
348
        eeprom_write_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + param_id), value);
350
        eeprom_write_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + param_id), value);
349
}
351
}
350
 
352
 
351
/***************************************************/
353
/***************************************************/
352
/*       Read Parameter from EEPROM as word        */
354
/*       Read Parameter from EEPROM as word        */
353
/***************************************************/
355
/***************************************************/
354
uint16_t GetParamWord(uint16_t param_id)
356
uint16_t GetParamWord(uint16_t param_id)
355
{
357
{
356
        return eeprom_read_word((uint16_t *)(EEPROM_ADR_PARAM_BEGIN + param_id));
358
        return eeprom_read_word((uint16_t *)(EEPROM_ADR_PARAM_BEGIN + param_id));
357
}
359
}
358
 
360
 
359
/***************************************************/
361
/***************************************************/
360
/*       Write Parameter to EEPROM as word         */
362
/*       Write Parameter to EEPROM as word         */
361
/***************************************************/
363
/***************************************************/
362
void SetParamWord(uint16_t param_id, uint16_t value)
364
void SetParamWord(uint16_t param_id, uint16_t value)
363
{
365
{
364
        eeprom_write_word((uint16_t*)(EEPROM_ADR_PARAM_BEGIN + param_id), value);
366
        eeprom_write_word((uint16_t*)(EEPROM_ADR_PARAM_BEGIN + param_id), value);
365
}
367
}
366
 
368
 
367
/***************************************************/
369
/***************************************************/
368
/*       Read Parameter Set from EEPROM            */
370
/*       Read Parameter Set from EEPROM            */
369
/***************************************************/
371
/***************************************************/
370
// number [1..5]
372
// number [1..5]
371
uint8_t ParamSet_ReadFromEEProm(uint8_t setnumber)
373
uint8_t ParamSet_ReadFromEEProm(uint8_t setnumber)
372
{
374
{
373
        uint8_t crc;
375
        uint8_t crc;
374
        uint16_t eeaddr;
376
        uint16_t eeaddr;
375
 
377
 
376
        // range the setnumber
378
        // range the setnumber
377
        if((1 > setnumber) || (setnumber > 5)) setnumber = 3;
379
        if((1 > setnumber) || (setnumber > 5)) setnumber = 3;
378
 
380
 
379
        // calculate eeprom addr
381
        // calculate eeprom addr
380
        eeaddr = EEPROM_ADR_PARAMSET + PARAMSET_STRUCT_LEN * (setnumber - 1);
382
        eeaddr = EEPROM_ADR_PARAMSET + PARAMSET_STRUCT_LEN * (setnumber - 1);
381
 
383
 
382
        // calculate checksum from eeprom
384
        // calculate checksum from eeprom
383
        crc = EEProm_Checksum(eeaddr, PARAMSET_STRUCT_LEN - 1);
385
        crc = EEProm_Checksum(eeaddr, PARAMSET_STRUCT_LEN - 1);
384
 
386
 
385
        // check crc
387
        // check crc
386
        if(crc != eeprom_read_byte((uint8_t*)(eeaddr + PARAMSET_STRUCT_LEN - 1))) return 0;
388
        if(crc != eeprom_read_byte((uint8_t*)(eeaddr + PARAMSET_STRUCT_LEN - 1))) return 0;
387
 
389
 
388
        // check revision
390
        // check revision
389
        if(eeprom_read_byte((uint8_t*)(eeaddr)) != EEPARAM_REVISION) return 0;
391
        if(eeprom_read_byte((uint8_t*)(eeaddr)) != EEPARAM_REVISION) return 0;
390
 
392
 
391
        // read paramset from eeprom
393
        // read paramset from eeprom
392
        eeprom_read_block((void *) &EE_Parameter, (void*)(EEPROM_ADR_PARAMSET + PARAMSET_STRUCT_LEN * (setnumber - 1)), PARAMSET_STRUCT_LEN);
394
        eeprom_read_block((void *) &EE_Parameter, (void*)(EEPROM_ADR_PARAMSET + PARAMSET_STRUCT_LEN * (setnumber - 1)), PARAMSET_STRUCT_LEN);
393
        LED_Init();
395
        LED_Init();
394
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__))
396
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__))
395
        LIBFC_HoTT_Clear();
397
        LIBFC_HoTT_Clear();
396
#endif
398
#endif
397
        return 1;
399
        return 1;
398
}
400
}
399
 
401
 
400
/***************************************************/
402
/***************************************************/
401
/*        Write Parameter Set to EEPROM            */
403
/*        Write Parameter Set to EEPROM            */
402
/***************************************************/
404
/***************************************************/
403
// number [1..5]
405
// number [1..5]
404
uint8_t ParamSet_WriteToEEProm(uint8_t setnumber)
406
uint8_t ParamSet_WriteToEEProm(uint8_t setnumber)
405
{
407
{
406
        uint8_t crc;
408
        uint8_t crc;
407
 
409
 
408
        if(EE_Parameter.Revision == EEPARAM_REVISION) // write only the right revision to eeprom
410
        if(EE_Parameter.Revision == EEPARAM_REVISION) // write only the right revision to eeprom
409
        {
411
        {
410
                if(setnumber > 5) setnumber = 5;
412
                if(setnumber > 5) setnumber = 5;
411
                if(setnumber < 1) return 0;
413
                if(setnumber < 1) return 0;
412
        LIBFC_CheckSettings();
414
        LIBFC_CheckSettings();
413
                if(EE_Parameter.GlobalConfig3 & CFG3_VARIO_FAILSAFE)         // check the Setting: Not more than 100% emergency gas
415
                if(EE_Parameter.GlobalConfig3 & CFG3_VARIO_FAILSAFE)         // check the Setting: Not more than 100% emergency gas
414
                        {
416
                        {
415
                         if(EE_Parameter.NotGas > 99) EE_Parameter.NotGas = 80; // i.e. 80% of Hovergas
417
                         if(EE_Parameter.NotGas > 99) EE_Parameter.NotGas = 80; // i.e. 80% of Hovergas
416
                        }
418
                        }
417
                // update checksum
419
                // update checksum
418
                EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
420
                EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
419
 
421
 
420
                // write paramset to eeprom
422
                // write paramset to eeprom
421
                eeprom_write_block((void *) &EE_Parameter, (void*)(EEPROM_ADR_PARAMSET + PARAMSET_STRUCT_LEN * (setnumber - 1)), PARAMSET_STRUCT_LEN);
423
                eeprom_write_block((void *) &EE_Parameter, (void*)(EEPROM_ADR_PARAMSET + PARAMSET_STRUCT_LEN * (setnumber - 1)), PARAMSET_STRUCT_LEN);
422
 
424
 
423
                // backup channel settings to separate block in eeprom
425
                // backup channel settings to separate block in eeprom
424
                eeprom_write_block( (void*)(EE_Parameter.Kanalbelegung), (void*)(EEPROM_ADR_CHANNELS), sizeof(EE_Parameter.Kanalbelegung));
426
                eeprom_write_block( (void*)(EE_Parameter.Kanalbelegung), (void*)(EEPROM_ADR_CHANNELS), sizeof(EE_Parameter.Kanalbelegung));
425
 
427
 
426
                // write crc of channel block to eeprom
428
                // write crc of channel block to eeprom
427
                crc = RAM_Checksum((uint8_t*)(EE_Parameter.Kanalbelegung), sizeof(EE_Parameter.Kanalbelegung));
429
                crc = RAM_Checksum((uint8_t*)(EE_Parameter.Kanalbelegung), sizeof(EE_Parameter.Kanalbelegung));
428
                eeprom_write_byte((uint8_t*)(EEPROM_ADR_CHANNELS + sizeof(EE_Parameter.Kanalbelegung)), crc);
430
                eeprom_write_byte((uint8_t*)(EEPROM_ADR_CHANNELS + sizeof(EE_Parameter.Kanalbelegung)), crc);
429
 
431
 
430
                // update active settings number
432
                // update active settings number
431
                SetActiveParamSet(setnumber);
433
                SetActiveParamSet(setnumber);
432
                LED_Init();
434
                LED_Init();
433
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__))
435
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__))
434
                LIBFC_HoTT_Clear();
436
                LIBFC_HoTT_Clear();
435
#endif
437
#endif
436
                return 1;
438
                return 1;
437
        }
439
        }
438
        // wrong revision
440
        // wrong revision
439
        return 0;
441
        return 0;
440
}
442
}
441
 
443
 
442
/***************************************************/
444
/***************************************************/
443
/*          Read MixerTable from EEPROM            */
445
/*          Read MixerTable from EEPROM            */
444
/***************************************************/
446
/***************************************************/
445
uint8_t MixerTable_ReadFromEEProm(void)
447
uint8_t MixerTable_ReadFromEEProm(void)
446
{
448
{
447
        uint8_t crc;
449
        uint8_t crc;
448
 
450
 
449
        // calculate checksum in eeprom
451
        // calculate checksum in eeprom
450
        crc = EEProm_Checksum(EEPROM_ADR_MIXERTABLE, sizeof(Mixer) - 1);
452
        crc = EEProm_Checksum(EEPROM_ADR_MIXERTABLE, sizeof(Mixer) - 1);
451
 
453
 
452
        // check crc
454
        // check crc
453
        if( crc != eeprom_read_byte((uint8_t*)(EEPROM_ADR_MIXERTABLE + sizeof(Mixer) - 1)) ) return 0;
455
        if( crc != eeprom_read_byte((uint8_t*)(EEPROM_ADR_MIXERTABLE + sizeof(Mixer) - 1)) ) return 0;
454
 
456
 
455
        // check revision
457
        // check revision
456
        if(eeprom_read_byte((uint8_t*)(EEPROM_ADR_MIXERTABLE)) != EEMIXER_REVISION) return 0;
458
        if(eeprom_read_byte((uint8_t*)(EEPROM_ADR_MIXERTABLE)) != EEMIXER_REVISION) return 0;
457
 
459
 
458
        // read mixer table
460
        // read mixer table
459
        eeprom_read_block((void *) &Mixer, (void*)(EEPROM_ADR_MIXERTABLE), sizeof(Mixer));
461
        eeprom_read_block((void *) &Mixer, (void*)(EEPROM_ADR_MIXERTABLE), sizeof(Mixer));
460
        return 1;
462
        return 1;
461
}
463
}
462
 
464
 
463
/***************************************************/
465
/***************************************************/
464
/*          Write Mixer Table to EEPROM            */
466
/*          Write Mixer Table to EEPROM            */
465
/***************************************************/
467
/***************************************************/
466
uint8_t MixerTable_WriteToEEProm(void)
468
uint8_t MixerTable_WriteToEEProm(void)
467
{
469
{
468
        if(Mixer.Revision == EEMIXER_REVISION)
470
        if(Mixer.Revision == EEMIXER_REVISION)
469
        {
471
        {
470
                // update crc
472
                // update crc
471
                Mixer.crc = RAM_Checksum((uint8_t*)(&Mixer), sizeof(Mixer) - 1);
473
                Mixer.crc = RAM_Checksum((uint8_t*)(&Mixer), sizeof(Mixer) - 1);
472
 
474
 
473
                // write to eeprom
475
                // write to eeprom
474
                eeprom_write_block((void *) &Mixer, (void*)(EEPROM_ADR_MIXERTABLE), sizeof(Mixer));
476
                eeprom_write_block((void *) &Mixer, (void*)(EEPROM_ADR_MIXERTABLE), sizeof(Mixer));
475
                return 1;
477
                return 1;
476
        }
478
        }
477
        else return 0;
479
        else return 0;
478
}
480
}
479
 
481
 
480
/***************************************************/
482
/***************************************************/
481
/*    Default Values for Mixer Table               */
483
/*    Default Values for Mixer Table               */
482
/***************************************************/
484
/***************************************************/
483
void MixerTable_Default(void) // Quadro
485
void MixerTable_Default(void) // Quadro
484
{
486
{
485
        uint8_t i;
487
        uint8_t i;
486
 
488
 
487
        Mixer.Revision = EEMIXER_REVISION;
489
        Mixer.Revision = EEMIXER_REVISION;
488
        // clear mixer table
490
        // clear mixer table
489
        for(i = 0; i < 16; i++)
491
        for(i = 0; i < 16; i++)
490
        {
492
        {
491
                Mixer.Motor[i][MIX_GAS]  = 0;
493
                Mixer.Motor[i][MIX_GAS]  = 0;
492
                Mixer.Motor[i][MIX_NICK] = 0;
494
                Mixer.Motor[i][MIX_NICK] = 0;
493
                Mixer.Motor[i][MIX_ROLL] = 0;
495
                Mixer.Motor[i][MIX_ROLL] = 0;
494
                Mixer.Motor[i][MIX_YAW]  = 0;
496
                Mixer.Motor[i][MIX_YAW]  = 0;
495
        }
497
        }
496
        // default = Quadro
498
        // default = Quadro
497
        Mixer.Motor[0][MIX_GAS] = 64; Mixer.Motor[0][MIX_NICK] = +64; Mixer.Motor[0][MIX_ROLL] =   0; Mixer.Motor[0][MIX_YAW] = +64;
499
        Mixer.Motor[0][MIX_GAS] = 64; Mixer.Motor[0][MIX_NICK] = +64; Mixer.Motor[0][MIX_ROLL] =   0; Mixer.Motor[0][MIX_YAW] = +64;
498
        Mixer.Motor[1][MIX_GAS] = 64; Mixer.Motor[1][MIX_NICK] = -64; Mixer.Motor[1][MIX_ROLL] =   0; Mixer.Motor[1][MIX_YAW] = +64;
500
        Mixer.Motor[1][MIX_GAS] = 64; Mixer.Motor[1][MIX_NICK] = -64; Mixer.Motor[1][MIX_ROLL] =   0; Mixer.Motor[1][MIX_YAW] = +64;
499
        Mixer.Motor[2][MIX_GAS] = 64; Mixer.Motor[2][MIX_NICK] =   0; Mixer.Motor[2][MIX_ROLL] = -64; Mixer.Motor[2][MIX_YAW] = -64;
501
        Mixer.Motor[2][MIX_GAS] = 64; Mixer.Motor[2][MIX_NICK] =   0; Mixer.Motor[2][MIX_ROLL] = -64; Mixer.Motor[2][MIX_YAW] = -64;
500
        Mixer.Motor[3][MIX_GAS] = 64; Mixer.Motor[3][MIX_NICK] =   0; Mixer.Motor[3][MIX_ROLL] = +64; Mixer.Motor[3][MIX_YAW] = -64;
502
        Mixer.Motor[3][MIX_GAS] = 64; Mixer.Motor[3][MIX_NICK] =   0; Mixer.Motor[3][MIX_ROLL] = +64; Mixer.Motor[3][MIX_YAW] = -64;
501
        memcpy(Mixer.Name, "Quadro\0\0\0\0\0\0", 12);
503
        memcpy(Mixer.Name, "Quadro\0\0\0\0\0\0", 12);
502
        Mixer.crc = RAM_Checksum((uint8_t*)(&Mixer), sizeof(Mixer) - 1);
504
        Mixer.crc = RAM_Checksum((uint8_t*)(&Mixer), sizeof(Mixer) - 1);
503
}
505
}
504
 
506
 
505
/***************************************************/
507
/***************************************************/
506
/*       Get active parameter set                  */
508
/*       Get active parameter set                  */
507
/***************************************************/
509
/***************************************************/
508
uint8_t GetActiveParamSet(void)
510
uint8_t GetActiveParamSet(void)
509
{
511
{
510
        uint8_t setnumber;
512
        uint8_t setnumber;
511
        setnumber = eeprom_read_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + PID_ACTIVE_SET));
513
        setnumber = eeprom_read_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + PID_ACTIVE_SET));
512
        if(setnumber > 5)
514
        if(setnumber > 5)
513
        {
515
        {
514
                setnumber = 3;
516
                setnumber = 3;
515
                eeprom_write_byte((void*)(EEPROM_ADR_PARAM_BEGIN+PID_ACTIVE_SET), setnumber);
517
                eeprom_write_byte((void*)(EEPROM_ADR_PARAM_BEGIN+PID_ACTIVE_SET), setnumber);
516
        }
518
        }
517
        ActiveParamSet = setnumber;
519
        ActiveParamSet = setnumber;
518
        return(setnumber);
520
        return(setnumber);
519
}
521
}
520
 
522
 
521
/***************************************************/
523
/***************************************************/
522
/*       Set active parameter set                  */
524
/*       Set active parameter set                  */
523
/***************************************************/
525
/***************************************************/
524
void SetActiveParamSet(uint8_t setnumber)
526
void SetActiveParamSet(uint8_t setnumber)
525
{
527
{
526
        if(setnumber > 5) setnumber = 5;
528
        if(setnumber > 5) setnumber = 5;
527
        if(setnumber < 1) setnumber = 1;
529
        if(setnumber < 1) setnumber = 1;
528
        ActiveParamSet = setnumber;
530
        ActiveParamSet = setnumber;
529
        eeprom_write_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + PID_ACTIVE_SET), setnumber);
531
        eeprom_write_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + PID_ACTIVE_SET), setnumber);
530
}
532
}
531
 
533
 
532
/***************************************************/
534
/***************************************************/
533
/*       Set default parameter set                 */
535
/*       Set default parameter set                 */
534
/***************************************************/
536
/***************************************************/
535
void SetDefaultParameter(uint8_t set, uint8_t restore_channels)
537
void SetDefaultParameter(uint8_t set, uint8_t restore_channels)
536
{
538
{
537
 
539
 
538
        if(set > 5) set = 5;
540
        if(set > 5) set = 5;
539
        else if(set < 1) set = 1;
541
        else if(set < 1) set = 1;
540
 
542
 
541
        switch(set)
543
        switch(set)
542
        {
544
        {
543
                case 1:
545
                case 1:
544
                        ParamSet_DefaultSet1(); // Fill ParamSet Structure to default parameter set 1 (Sport)
546
                        ParamSet_DefaultSet1(); // Fill ParamSet Structure to default parameter set 1 (Sport)
545
                        break;
547
                        break;
546
                case 2:
548
                case 2:
547
                        ParamSet_DefaultSet2(); // Kamera
549
                        ParamSet_DefaultSet2(); // Kamera
548
                        break;
550
                        break;
549
                case 3:
551
                case 3:
550
                        ParamSet_DefaultSet3(); // Beginner
552
                        ParamSet_DefaultSet3(); // Beginner
551
                        break;
553
                        break;
552
                default:
554
                default:
553
                        ParamSet_DefaultSet3(); // Beginner
555
                        ParamSet_DefaultSet3(); // Beginner
554
                        break;
556
                        break;
555
        }
557
        }
556
        if(restore_channels)
558
        if(restore_channels)
557
        {
559
        {
558
                uint8_t crc;
560
                uint8_t crc;
559
                // 1st check for a valid channel backup in eeprom
561
                // 1st check for a valid channel backup in eeprom
560
                crc = EEProm_Checksum(EEPROM_ADR_CHANNELS, sizeof(EE_Parameter.Kanalbelegung));
562
                crc = EEProm_Checksum(EEPROM_ADR_CHANNELS, sizeof(EE_Parameter.Kanalbelegung));
561
                if(crc == eeprom_read_byte((uint8_t*)(EEPROM_ADR_CHANNELS + sizeof(EE_Parameter.Kanalbelegung))) )
563
                if(crc == eeprom_read_byte((uint8_t*)(EEPROM_ADR_CHANNELS + sizeof(EE_Parameter.Kanalbelegung))) )
562
                {
564
                {
563
                        eeprom_read_block((void *)EE_Parameter.Kanalbelegung, (void*)(EEPROM_ADR_CHANNELS), sizeof(EE_Parameter.Kanalbelegung));
565
                        eeprom_read_block((void *)EE_Parameter.Kanalbelegung, (void*)(EEPROM_ADR_CHANNELS), sizeof(EE_Parameter.Kanalbelegung));
564
                }
566
                }
565
                else ParamSet_DefaultStickMapping();
567
                else ParamSet_DefaultStickMapping();
566
        }
568
        }
567
        else ParamSet_DefaultStickMapping();
569
        else ParamSet_DefaultStickMapping();
568
        ParamSet_WriteToEEProm(set);
570
        ParamSet_WriteToEEProm(set);
569
}
571
}
570
 
572
 
571
/***************************************************/
573
/***************************************************/
572
/*       Initialize EEPROM Parameter Sets          */
574
/*       Initialize EEPROM Parameter Sets          */
573
/***************************************************/
575
/***************************************************/
574
void ParamSet_Init(void)
576
void ParamSet_Init(void)
575
{
577
{
576
        uint8_t channel_backup  = 0, bad_params = 0, ee_default = 0,i;
578
        uint8_t channel_backup  = 0, bad_params = 0, ee_default = 0,i;
577
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__))
579
#if (defined(__AVR_ATmega1284__) || defined(__AVR_ATmega1284P__))
578
        if(PlatinenVersion != GetParamByte(PID_HARDWARE_VERSION))
580
        if(PlatinenVersion != GetParamByte(PID_HARDWARE_VERSION))
579
         {
581
         {
580
          if(PlatinenVersion == 22 && GetParamByte(PID_HARDWARE_VERSION) == 21 && !(PIND & 0x10)) SetParamByte(PID_EE_REVISION,0); // reset the Settings if the Version changed to V2.2
582
          if(PlatinenVersion == 22 && GetParamByte(PID_HARDWARE_VERSION) == 21 && !(PIND & 0x10)) SetParamByte(PID_EE_REVISION,0); // reset the Settings if the Version changed to V2.2
581
          SetParamByte(PID_HARDWARE_VERSION,PlatinenVersion); // Remember the Version number
583
          SetParamByte(PID_HARDWARE_VERSION,PlatinenVersion); // Remember the Version number
582
          wdt_enable(WDTO_15MS); // Reset-Commando
584
          wdt_enable(WDTO_15MS); // Reset-Commando
583
          printf("\n\r--> Hardware Version Byte Changed <--");
585
          printf("\n\r--> Hardware Version Byte Changed <--");
584
          while(1);
586
          while(1);
585
         }
587
         }
586
#endif
588
#endif
587
        if((EEPARAM_REVISION) != GetParamByte(PID_EE_REVISION))  
589
        if((EEPARAM_REVISION) != GetParamByte(PID_EE_REVISION))  
588
        {
590
        {
589
                ee_default = 1; // software update or forced by mktool
591
                ee_default = 1; // software update or forced by mktool
590
        }
592
        }
591
        // 1st check for a valid channel backup in eeprom
593
        // 1st check for a valid channel backup in eeprom
592
        i = EEProm_Checksum(EEPROM_ADR_CHANNELS, sizeof(EE_Parameter.Kanalbelegung));
594
        i = EEProm_Checksum(EEPROM_ADR_CHANNELS, sizeof(EE_Parameter.Kanalbelegung));
593
        if(i == eeprom_read_byte((uint8_t*)(EEPROM_ADR_CHANNELS + sizeof(EE_Parameter.Kanalbelegung)))) channel_backup = 1;
595
        if(i == eeprom_read_byte((uint8_t*)(EEPROM_ADR_CHANNELS + sizeof(EE_Parameter.Kanalbelegung)))) channel_backup = 1;
594
 
596
 
595
        // parameter check
597
        // parameter check
596
 
598
 
597
        // check all 5 parameter settings
599
        // check all 5 parameter settings
598
        for (i = 1;i < 6; i++)
600
        for (i = 1;i < 6; i++)
599
        {
601
        {
600
                if(ee_default || !ParamSet_ReadFromEEProm(i)) // could not read paramset from eeprom
602
                if(ee_default || !ParamSet_ReadFromEEProm(i)) // could not read paramset from eeprom
601
                {
603
                {
602
                        bad_params = 1;
604
                        bad_params = 1;
603
                        printf("\n\rGenerating default Parameter Set %d",i);
605
                        printf("\n\rGenerating default Parameter Set %d",i);
604
                        switch(i)
606
                        switch(i)
605
                        {
607
                        {
606
                                case 1:
608
                                case 1:
607
                                        ParamSet_DefaultSet1(); // Fill ParamSet Structure to default parameter set 1 (Sport)
609
                                        ParamSet_DefaultSet1(); // Fill ParamSet Structure to default parameter set 1 (Sport)
608
                                        break;
610
                                        break;
609
                                case 2:
611
                                case 2:
610
                                        ParamSet_DefaultSet2(); // Normal
612
                                        ParamSet_DefaultSet2(); // Normal
611
                                        break;
613
                                        break;
612
                                default:
614
                                default:
613
                                        ParamSet_DefaultSet3(); // Easy
615
                                        ParamSet_DefaultSet3(); // Easy
614
                                        break;
616
                                        break;
615
                        }
617
                        }
616
                        if(channel_backup) // if we have an channel mapping backup in eeprom
618
                        if(channel_backup) // if we have an channel mapping backup in eeprom
617
                        {       // restore it from eeprom
619
                        {       // restore it from eeprom
618
                                eeprom_read_block((void *)EE_Parameter.Kanalbelegung, (void*)(EEPROM_ADR_CHANNELS), sizeof(EE_Parameter.Kanalbelegung));
620
                                eeprom_read_block((void *)EE_Parameter.Kanalbelegung, (void*)(EEPROM_ADR_CHANNELS), sizeof(EE_Parameter.Kanalbelegung));
619
                        }
621
                        }
620
                        else
622
                        else
621
                        {       // use default mapping
623
                        {       // use default mapping
622
                                ParamSet_DefaultStickMapping();
624
                                ParamSet_DefaultStickMapping();
623
                        }
625
                        }
624
                        ParamSet_WriteToEEProm(i);
626
                        ParamSet_WriteToEEProm(i);
625
                }
627
                }
626
        }
628
        }
627
        if(bad_params) // at least one of the parameter settings were invalid
629
        if(bad_params) // at least one of the parameter settings were invalid
628
        {
630
        {
629
                // default-Setting is parameter set 3
631
                // default-Setting is parameter set 3
630
                SetActiveParamSet(3);
632
                SetActiveParamSet(3);
631
        }
633
        }
632
        // read active parameter set to ParamSet stucture
634
        // read active parameter set to ParamSet stucture
633
        i = GetActiveParamSet();
635
        i = GetActiveParamSet();
634
        ParamSet_ReadFromEEProm(i);
636
        ParamSet_ReadFromEEProm(i);
635
        printf("\n\rUsing Parameter Set %d", i);
637
        printf("\n\rUsing Parameter Set %d", i);
636
 
638
 
637
        // load mixer table
639
        // load mixer table
638
        if(GetParamByte(PID_EE_REVISION) == 0xff || !MixerTable_ReadFromEEProm() )
640
        if(GetParamByte(PID_EE_REVISION) == 0xff || !MixerTable_ReadFromEEProm() )
639
        {
641
        {
640
                printf("\n\rGenerating default Mixer Table");
642
                printf("\n\rGenerating default Mixer Table");
641
                MixerTable_Default(); // Quadro
643
                MixerTable_Default(); // Quadro
642
                MixerTable_WriteToEEProm();
644
                MixerTable_WriteToEEProm();
643
        }
645
        }
644
        if(ee_default)  SetParamByte(PID_EE_REVISION, (EEPARAM_REVISION));
646
        if(ee_default)  SetParamByte(PID_EE_REVISION, (EEPARAM_REVISION));
645
        // determine motornumber
647
        // determine motornumber
646
        RequiredMotors = 0;
648
        RequiredMotors = 0;
647
        for(i = 0; i < 16; i++)
649
        for(i = 0; i < 16; i++)
648
        {
650
        {
649
                if(Mixer.Motor[i][MIX_GAS] > 0) RequiredMotors++;
651
                if(Mixer.Motor[i][MIX_GAS] > 0) RequiredMotors++;
650
        }
652
        }
651
 
653
 
652
        printf("\n\rMixer-Config: '%s' (%u Motors)",Mixer.Name, RequiredMotors);
654
        printf("\n\rMixer-Config: '%s' (%u Motors)",Mixer.Name, RequiredMotors);
653
 PrintLine();// ("\n\r===================================");
655
 PrintLine();// ("\n\r===================================");
654
 
656
 
655
}
657
}
656
 
658