Subversion Repositories FlightCtrl

Rev

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

Rev 1762 Rev 1769
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
 
-
 
53
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
-
 
54
// + Contant Values
-
 
55
// + 0-250 -> normale Values
-
 
56
// + 251 -> Poti1
-
 
57
// + 252 -> Poti2
-
 
58
// + 253 -> Poti3
-
 
59
// + 254 -> Poti4
-
 
60
// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
52
 
61
 
53
 
62
#ifndef EEMEM
54
#ifndef EEMEM
63
#define EEMEM __attribute__ ((section (".eeprom")))
55
#define EEMEM __attribute__ ((section (".eeprom")))
64
#endif
56
#endif
65
 
57
 
66
 
58
 
67
#include <avr/eeprom.h>
59
#include <avr/eeprom.h>
68
#include <string.h>
60
#include <string.h>
69
#include "eeprom.h"
61
#include "eeprom.h"
70
#include "uart.h"
62
#include "uart.h"
71
#include "led.h"
63
#include "led.h"
72
#include "main.h"
64
#include "main.h"
73
#include "fc.h"
65
#include "fc.h"
74
#include "twimaster.h"
66
#include "twimaster.h"
75
 
67
 
76
paramset_t              EE_Parameter;
68
paramset_t              EE_Parameter;
77
MixerTable_t    Mixer;
69
MixerTable_t    Mixer;
78
uint8_t RequiredMotors;
70
uint8_t RequiredMotors;
79
 
71
 
80
 
72
 
81
uint8_t RAM_Checksum(uint8_t* pBuffer, uint16_t len)
73
uint8_t RAM_Checksum(uint8_t* pBuffer, uint16_t len)
82
{
74
{
83
        uint8_t crc = 0xAA;
75
        uint8_t crc = 0xAA;
84
        uint16_t i;
76
        uint16_t i;
85
 
77
 
86
        for(i=0; i<len; i++)
78
        for(i=0; i<len; i++)
87
        {
79
        {
88
                crc += pBuffer[i];
80
                crc += pBuffer[i];
89
        }
81
        }
90
        return crc;
82
        return crc;
91
}
83
}
92
 
84
 
93
uint8_t EEProm_Checksum(uint16_t EEAddr, uint16_t len)
85
uint8_t EEProm_Checksum(uint16_t EEAddr, uint16_t len)
94
{
86
{
95
        uint8_t crc = 0xAA;
87
        uint8_t crc = 0xAA;
96
        uint16_t off;
88
        uint16_t off;
97
 
89
 
98
        for(off=0; off<len; off++)
90
        for(off=0; off<len; off++)
99
        {
91
        {
100
                crc += eeprom_read_byte((uint8_t*)(EEAddr + off));;
92
                crc += eeprom_read_byte((uint8_t*)(EEAddr + off));;
101
        }
93
        }
102
        return crc;
94
        return crc;
103
}
95
}
104
 
96
 
105
void ParamSet_DefaultStickMapping(void)
97
void ParamSet_DefaultStickMapping(void)
106
{
98
{
107
        EE_Parameter.Kanalbelegung[K_GAS]   = 1;
99
        EE_Parameter.Kanalbelegung[K_GAS]   = 1;
108
        EE_Parameter.Kanalbelegung[K_ROLL]  = 2;
100
        EE_Parameter.Kanalbelegung[K_ROLL]  = 2;
109
        EE_Parameter.Kanalbelegung[K_NICK]  = 3;
101
        EE_Parameter.Kanalbelegung[K_NICK]  = 3;
110
        EE_Parameter.Kanalbelegung[K_GIER]  = 4;
102
        EE_Parameter.Kanalbelegung[K_GIER]  = 4;
111
        EE_Parameter.Kanalbelegung[K_POTI1] = 5;
103
        EE_Parameter.Kanalbelegung[K_POTI1] = 5;
112
        EE_Parameter.Kanalbelegung[K_POTI2] = 6;
104
        EE_Parameter.Kanalbelegung[K_POTI2] = 6;
113
        EE_Parameter.Kanalbelegung[K_POTI3] = 7;
105
        EE_Parameter.Kanalbelegung[K_POTI3] = 7;
114
        EE_Parameter.Kanalbelegung[K_POTI4] = 8;
106
        EE_Parameter.Kanalbelegung[K_POTI4] = 8;
115
        EE_Parameter.Kanalbelegung[K_POTI5] = 9;
107
        EE_Parameter.Kanalbelegung[K_POTI5] = 9;
116
        EE_Parameter.Kanalbelegung[K_POTI6] = 10;
108
        EE_Parameter.Kanalbelegung[K_POTI6] = 10;
117
        EE_Parameter.Kanalbelegung[K_POTI7] = 11;
109
        EE_Parameter.Kanalbelegung[K_POTI7] = 11;
118
        EE_Parameter.Kanalbelegung[K_POTI8] = 12;
110
        EE_Parameter.Kanalbelegung[K_POTI8] = 12;
119
}
111
}
120
 
112
 
121
 
113
 
122
/***************************************************/
114
/***************************************************/
123
/*    Default Values for parameter set 1           */
115
/*    Default Values for parameter set 1           */
124
/***************************************************/
116
/***************************************************/
125
void CommonDefaults(void)
117
void CommonDefaults(void)
126
{
118
{
127
        EE_Parameter.Revision = EEPARAM_REVISION;
119
        EE_Parameter.Revision = EEPARAM_REVISION;
128
 
120
 
129
        if(PlatinenVersion >= 20)
121
        if(PlatinenVersion >= 20)
130
        {
122
        {
131
                EE_Parameter.Gyro_D = 10;
123
                EE_Parameter.Gyro_D = 10;
132
                EE_Parameter.Driftkomp = 0;
124
                EE_Parameter.Driftkomp = 0;
133
                EE_Parameter.GyroAccFaktor = 27;
125
                EE_Parameter.GyroAccFaktor = 27;
134
                EE_Parameter.WinkelUmschlagNick = 78;
126
                EE_Parameter.WinkelUmschlagNick = 78;
135
                EE_Parameter.WinkelUmschlagRoll = 78;
127
                EE_Parameter.WinkelUmschlagRoll = 78;
136
        }
128
        }
137
        else
129
        else
138
        {
130
        {
139
                EE_Parameter.Gyro_D = 3;
131
                EE_Parameter.Gyro_D = 3;
140
                EE_Parameter.Driftkomp = 32;
132
                EE_Parameter.Driftkomp = 32;
141
                EE_Parameter.GyroAccFaktor = 30;
133
                EE_Parameter.GyroAccFaktor = 30;
142
                EE_Parameter.WinkelUmschlagNick = 85;
134
                EE_Parameter.WinkelUmschlagNick = 85;
143
                EE_Parameter.WinkelUmschlagRoll = 85;
135
                EE_Parameter.WinkelUmschlagRoll = 85;
144
        }
136
        }
145
        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;
146
        EE_Parameter.ExtraConfig = CFG2_HEIGHT_LIMIT | CFG2_VARIO_BEEP;
138
        EE_Parameter.ExtraConfig = CFG2_HEIGHT_LIMIT | CFG2_VARIO_BEEP;
147
        EE_Parameter.Receiver = RECEIVER_SPEKTRUM;
139
        EE_Parameter.Receiver = RECEIVER_SPEKTRUM;
148
        EE_Parameter.MotorSafetySwitch = 0;
140
        EE_Parameter.MotorSafetySwitch = 0;
-
 
141
        EE_Parameter.ExternalControl = 0;
149
 
142
 
150
        EE_Parameter.Gas_Min = 8;             // Wert : 0-32
143
        EE_Parameter.Gas_Min = 8;             // Wert : 0-32
151
        EE_Parameter.Gas_Max = 230;           // Wert : 33-247
144
        EE_Parameter.Gas_Max = 230;           // Wert : 33-247
152
        EE_Parameter.KompassWirkung = 128;    // Wert : 0-247
145
        EE_Parameter.KompassWirkung = 128;    // Wert : 0-247
153
 
146
 
154
        EE_Parameter.Hoehe_MinGas = 30;
147
        EE_Parameter.Hoehe_MinGas = 30;
155
        EE_Parameter.MaxHoehe     = 255;         // Wert : 0-247   255 -> Poti1
148
        EE_Parameter.MaxHoehe     = 255;         // Wert : 0-247   255 -> Poti1
156
        EE_Parameter.Hoehe_P      = 15;          // Wert : 0-32
149
        EE_Parameter.Hoehe_P      = 15;          // Wert : 0-32
157
        EE_Parameter.Luftdruck_D  = 30;          // Wert : 0-247
150
        EE_Parameter.Luftdruck_D  = 30;          // Wert : 0-247
158
        EE_Parameter.Hoehe_ACC_Wirkung = 0;     // Wert : 0-247
151
        EE_Parameter.Hoehe_ACC_Wirkung = 0;     // Wert : 0-247
159
        EE_Parameter.Hoehe_HoverBand = 8;         // Wert : 0-247
152
        EE_Parameter.Hoehe_HoverBand = 8;         // Wert : 0-247
160
        EE_Parameter.Hoehe_GPS_Z = 64;           // Wert : 0-247
153
        EE_Parameter.Hoehe_GPS_Z = 64;           // Wert : 0-247
161
        EE_Parameter.Hoehe_StickNeutralPoint = 0;// Wert : 0-247 (0 = Hover-Estimation)
154
        EE_Parameter.Hoehe_StickNeutralPoint = 0;// Wert : 0-247 (0 = Hover-Estimation)
162
        EE_Parameter.Hoehe_Verstaerkung = 15;    // Wert : 0-50
155
        EE_Parameter.Hoehe_Verstaerkung = 15;    // Wert : 0-50
163
 
156
 
164
        EE_Parameter.UserParam1 =   0;           // zur freien Verwendung
157
        EE_Parameter.UserParam1 =   0;           // zur freien Verwendung
165
        EE_Parameter.UserParam2 =   0;           // zur freien Verwendung
158
        EE_Parameter.UserParam2 =   0;           // zur freien Verwendung
166
        EE_Parameter.UserParam3 =   0;           // zur freien Verwendung
159
        EE_Parameter.UserParam3 =   0;           // zur freien Verwendung
167
        EE_Parameter.UserParam4 =   0;           // zur freien Verwendung
160
        EE_Parameter.UserParam4 =   0;           // zur freien Verwendung
168
        EE_Parameter.UserParam5 =   0;           // zur freien Verwendung
161
        EE_Parameter.UserParam5 =   0;           // zur freien Verwendung
169
        EE_Parameter.UserParam6 =   0;           // zur freien Verwendung
162
        EE_Parameter.UserParam6 =   0;           // zur freien Verwendung
170
        EE_Parameter.UserParam7 = 0;             // zur freien Verwendung
163
        EE_Parameter.UserParam7 = 0;             // zur freien Verwendung
171
        EE_Parameter.UserParam8 = 0;             // zur freien Verwendung
164
        EE_Parameter.UserParam8 = 0;             // zur freien Verwendung
172
 
165
 
173
        EE_Parameter.ServoNickControl = 100;     // Wert : 0-247     // Stellung des Servos
166
        EE_Parameter.ServoNickControl = 100;     // Wert : 0-247     // Stellung des Servos
174
        EE_Parameter.ServoNickComp = 40;         // Wert : 0-247     // Einfluss Gyro/Servo
167
        EE_Parameter.ServoNickComp = 40;         // Wert : 0-247     // Einfluss Gyro/Servo
175
        EE_Parameter.ServoCompInvert = 1;        // Wert : 0-247     // Richtung Einfluss Gyro/Servo
168
        EE_Parameter.ServoCompInvert = 1;        // Wert : 0-247     // Richtung Einfluss Gyro/Servo
176
        EE_Parameter.ServoNickMin = 15;           // Wert : 0-247     // Anschlag
169
        EE_Parameter.ServoNickMin = 15;           // Wert : 0-247     // Anschlag
177
        EE_Parameter.ServoNickMax = 255;         // Wert : 0-247     // Anschlag
170
        EE_Parameter.ServoNickMax = 255;         // Wert : 0-247     // Anschlag
178
        EE_Parameter.ServoNickRefresh = 5;
171
        EE_Parameter.ServoNickRefresh = 5;
179
        EE_Parameter.Servo3 = 125;
172
        EE_Parameter.Servo3 = 125;
180
        EE_Parameter.Servo4 = 125;
173
        EE_Parameter.Servo4 = 125;
181
        EE_Parameter.Servo5 = 125;
174
        EE_Parameter.Servo5 = 125;
182
        EE_Parameter.ServoRollControl = 100;     // Wert : 0-247     // Stellung des Servos
175
        EE_Parameter.ServoRollControl = 100;     // Wert : 0-247     // Stellung des Servos
183
        EE_Parameter.ServoRollComp = 40;         // Wert : 0-247     // Einfluss Gyro/Servo
176
        EE_Parameter.ServoRollComp = 40;         // Wert : 0-247     // Einfluss Gyro/Servo
184
        EE_Parameter.ServoRollMin = 0;           // Wert : 0-247     // Anschlag
177
        EE_Parameter.ServoRollMin = 0;           // Wert : 0-247     // Anschlag
185
        EE_Parameter.ServoRollMax = 247;         // Wert : 0-247     // Anschlag
178
        EE_Parameter.ServoRollMax = 247;         // Wert : 0-247     // Anschlag
186
        EE_Parameter.ServoManualControlSpeed = 30;
179
        EE_Parameter.ServoManualControlSpeed = 40;
187
        EE_Parameter.CamOrientation = 0;
180
        EE_Parameter.CamOrientation = 0;
188
 
181
 
189
        EE_Parameter.J16Bitmask = 95;
182
        EE_Parameter.J16Bitmask = 95;
190
        EE_Parameter.J17Bitmask = 243;
183
        EE_Parameter.J17Bitmask = 243;
191
        EE_Parameter.WARN_J16_Bitmask = 0xAA;
184
        EE_Parameter.WARN_J16_Bitmask = 0xAA;
192
        EE_Parameter.WARN_J17_Bitmask = 0xAA;
185
        EE_Parameter.WARN_J17_Bitmask = 0xAA;
193
        EE_Parameter.J16Timing = 20;
186
        EE_Parameter.J16Timing = 20;
194
        EE_Parameter.J17Timing = 20;
187
        EE_Parameter.J17Timing = 20;
195
 
188
 
196
        EE_Parameter.LoopGasLimit = 50;
189
        EE_Parameter.LoopGasLimit = 50;
197
        EE_Parameter.LoopThreshold = 90;         // Wert: 0-247  Schwelle für Stickausschlag
190
        EE_Parameter.LoopThreshold = 90;         // Wert: 0-247  Schwelle für Stickausschlag
198
        EE_Parameter.LoopHysterese = 50;
191
        EE_Parameter.LoopHysterese = 50;
199
        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
200
 
193
 
201
        EE_Parameter.NaviGpsModeControl = 254; // 254 -> Poti 2
194
        EE_Parameter.NaviGpsModeControl = 254; // 254 -> Poti 2
202
        EE_Parameter.NaviGpsGain = 100;
195
        EE_Parameter.NaviGpsGain = 100;
203
        EE_Parameter.NaviGpsP = 90;
196
        EE_Parameter.NaviGpsP = 90;
204
        EE_Parameter.NaviGpsI = 90;
197
        EE_Parameter.NaviGpsI = 90;
205
        EE_Parameter.NaviGpsD = 90;
198
        EE_Parameter.NaviGpsD = 90;
206
        EE_Parameter.NaviGpsPLimit = 75;
199
        EE_Parameter.NaviGpsPLimit = 75;
207
        EE_Parameter.NaviGpsILimit = 75;
200
        EE_Parameter.NaviGpsILimit = 75;
208
        EE_Parameter.NaviGpsDLimit = 75;
201
        EE_Parameter.NaviGpsDLimit = 75;
209
        EE_Parameter.NaviGpsACC = 0;
202
        EE_Parameter.NaviGpsACC = 0;
210
        EE_Parameter.NaviGpsMinSat = 6;
203
        EE_Parameter.NaviGpsMinSat = 6;
211
        EE_Parameter.NaviStickThreshold = 8;
204
        EE_Parameter.NaviStickThreshold = 8;
212
        EE_Parameter.NaviWindCorrection = 90;
205
        EE_Parameter.NaviWindCorrection = 90;
213
        EE_Parameter.NaviSpeedCompensation = 30;
206
        EE_Parameter.NaviSpeedCompensation = 30;
214
        EE_Parameter.NaviOperatingRadius = 100;
207
        EE_Parameter.NaviOperatingRadius = 100;
215
        EE_Parameter.NaviAngleLimitation = 100;
208
        EE_Parameter.NaviAngleLimitation = 100;
216
        EE_Parameter.NaviPH_LoginTime = 2;
209
        EE_Parameter.NaviPH_LoginTime = 2;
217
        EE_Parameter.OrientationAngle = 0;
210
        EE_Parameter.OrientationAngle = 0;
218
        EE_Parameter.OrientationModeControl = 0;
211
        EE_Parameter.OrientationModeControl = 0;
219
        EE_Parameter.UnterspannungsWarnung = 33; // Wert : 0-247 ( Automatische Zellenerkennung bei < 50)
212
        EE_Parameter.UnterspannungsWarnung = 33; // Wert : 0-247 ( Automatische Zellenerkennung bei < 50)
220
        EE_Parameter.NotGas = 45;                // Wert : 0-247     // Gaswert bei Empangsverlust
213
        EE_Parameter.NotGas = 45;                // Wert : 0-247     // Gaswert bei Empangsverlust
221
        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
222
}
215
}
223
 
216
 
224
void ParamSet_DefaultSet1(void) // sport
217
void ParamSet_DefaultSet1(void) // sport
225
{
218
{
226
        CommonDefaults();
219
        CommonDefaults();
227
        EE_Parameter.Stick_P = 14;            // Wert : 1-20
220
        EE_Parameter.Stick_P = 14;            // Wert : 1-20
228
        EE_Parameter.Stick_D = 16;            // Wert : 0-20
221
        EE_Parameter.Stick_D = 16;            // Wert : 0-20
229
        EE_Parameter.Gier_P = 12;             // Wert : 1-20
222
        EE_Parameter.Gier_P = 12;             // Wert : 1-20
230
        EE_Parameter.Gyro_P = 80;             // Wert : 0-247
223
        EE_Parameter.Gyro_P = 80;             // Wert : 0-247
231
        EE_Parameter.Gyro_I = 150;            // Wert : 0-247
224
        EE_Parameter.Gyro_I = 150;            // Wert : 0-247
232
        EE_Parameter.Gyro_Gier_P = 80;        // Wert : 0-247
225
        EE_Parameter.Gyro_Gier_P = 80;        // Wert : 0-247
233
        EE_Parameter.Gyro_Gier_I = 150;       // Wert : 0-247
226
        EE_Parameter.Gyro_Gier_I = 150;       // Wert : 0-247
234
        EE_Parameter.Gyro_Stability = 6;          // Wert : 1-8
227
        EE_Parameter.Gyro_Stability = 6;          // Wert : 1-8
235
        EE_Parameter.I_Faktor = 32;
228
        EE_Parameter.I_Faktor = 32;
236
        EE_Parameter.AchsKopplung1 = 90;
229
        EE_Parameter.AchsKopplung1 = 90;
237
        EE_Parameter.AchsKopplung2 = 80;
230
        EE_Parameter.AchsKopplung2 = 80;
238
        EE_Parameter.CouplingYawCorrection = 1;
231
        EE_Parameter.CouplingYawCorrection = 1;
239
        EE_Parameter.GyroAccAbgleich = 16;        // 1/k;
232
        EE_Parameter.GyroAccAbgleich = 16;        // 1/k;
240
        EE_Parameter.DynamicStability = 100;
233
        EE_Parameter.DynamicStability = 100;
241
        memcpy(EE_Parameter.Name, "Sport\0", 12);
234
        memcpy(EE_Parameter.Name, "Sport\0", 12);
242
        EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
235
        EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
243
}
236
}
244
 
237
 
245
 
238
 
246
/***************************************************/
239
/***************************************************/
247
/*    Default Values for parameter set 2           */
240
/*    Default Values for parameter set 2           */
248
/***************************************************/
241
/***************************************************/
249
void ParamSet_DefaultSet2(void) // normal
242
void ParamSet_DefaultSet2(void) // normal
250
{
243
{
251
        CommonDefaults();
244
        CommonDefaults();
252
        EE_Parameter.Stick_P = 10;               // Wert : 1-20
245
        EE_Parameter.Stick_P = 10;               // Wert : 1-20
253
        EE_Parameter.Stick_D = 16;               // Wert : 0-20
246
        EE_Parameter.Stick_D = 16;               // Wert : 0-20
254
        EE_Parameter.Gier_P = 6;                 // Wert : 1-20
247
        EE_Parameter.Gier_P = 6;                 // Wert : 1-20
255
        EE_Parameter.Gyro_P = 90;                // Wert : 0-247
248
        EE_Parameter.Gyro_P = 90;                // Wert : 0-247
256
        EE_Parameter.Gyro_I = 120;               // Wert : 0-247
249
        EE_Parameter.Gyro_I = 120;               // Wert : 0-247
257
        EE_Parameter.Gyro_Gier_P = 90;           // Wert : 0-247
250
        EE_Parameter.Gyro_Gier_P = 90;           // Wert : 0-247
258
        EE_Parameter.Gyro_Gier_I = 120;          // Wert : 0-247
251
        EE_Parameter.Gyro_Gier_I = 120;          // Wert : 0-247
259
        EE_Parameter.Gyro_Stability = 6;                  // Wert : 1-8
252
        EE_Parameter.Gyro_Stability = 6;                  // Wert : 1-8
260
        EE_Parameter.I_Faktor = 32;
253
        EE_Parameter.I_Faktor = 32;
261
        EE_Parameter.AchsKopplung1 = 90;
254
        EE_Parameter.AchsKopplung1 = 90;
262
        EE_Parameter.AchsKopplung2 = 80;
255
        EE_Parameter.AchsKopplung2 = 80;
263
        EE_Parameter.CouplingYawCorrection = 60;
256
        EE_Parameter.CouplingYawCorrection = 60;
264
        EE_Parameter.GyroAccAbgleich = 32;        // 1/k
257
        EE_Parameter.GyroAccAbgleich = 32;        // 1/k
265
        EE_Parameter.DynamicStability = 75;
258
        EE_Parameter.DynamicStability = 75;
266
        memcpy(EE_Parameter.Name, "Normal\0", 12);
259
        memcpy(EE_Parameter.Name, "Normal\0", 12);
267
        EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
260
        EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
268
}
261
}
269
 
262
 
270
 
263
 
271
/***************************************************/
264
/***************************************************/
272
/*    Default Values for parameter set 3           */
265
/*    Default Values for parameter set 3           */
273
/***************************************************/
266
/***************************************************/
274
void ParamSet_DefaultSet3(void) // beginner
267
void ParamSet_DefaultSet3(void) // beginner
275
{
268
{
276
        CommonDefaults();
269
        CommonDefaults();
277
        EE_Parameter.Stick_P = 8;                // Wert : 1-20
270
        EE_Parameter.Stick_P = 8;                // Wert : 1-20
278
        EE_Parameter.Stick_D = 16;               // Wert : 0-20
271
        EE_Parameter.Stick_D = 16;               // Wert : 0-20
279
        EE_Parameter.Gier_P  = 6;                // Wert : 1-20
272
        EE_Parameter.Gier_P  = 6;                // Wert : 1-20
280
        EE_Parameter.Gyro_P = 100;               // Wert : 0-247
273
        EE_Parameter.Gyro_P = 100;               // Wert : 0-247
281
        EE_Parameter.Gyro_I = 120;               // Wert : 0-247
274
        EE_Parameter.Gyro_I = 120;               // Wert : 0-247
282
        EE_Parameter.Gyro_Gier_P = 100;          // Wert : 0-247
275
        EE_Parameter.Gyro_Gier_P = 100;          // Wert : 0-247
283
        EE_Parameter.Gyro_Gier_I = 120;          // Wert : 0-247
276
        EE_Parameter.Gyro_Gier_I = 120;          // Wert : 0-247
284
        EE_Parameter.Gyro_Stability = 6;                  // Wert : 1-8
277
        EE_Parameter.Gyro_Stability = 6;                  // Wert : 1-8
285
        EE_Parameter.I_Faktor = 16;
278
        EE_Parameter.I_Faktor = 16;
286
        EE_Parameter.AchsKopplung1 = 90;
279
        EE_Parameter.AchsKopplung1 = 90;
287
        EE_Parameter.AchsKopplung2 = 80;
280
        EE_Parameter.AchsKopplung2 = 80;
288
        EE_Parameter.CouplingYawCorrection = 70;
281
        EE_Parameter.CouplingYawCorrection = 70;
289
        EE_Parameter.GyroAccAbgleich = 32;        // 1/k
282
        EE_Parameter.GyroAccAbgleich = 32;        // 1/k
290
        EE_Parameter.DynamicStability = 70;
283
        EE_Parameter.DynamicStability = 70;
291
        memcpy(EE_Parameter.Name, "Beginner\0", 12);
284
        memcpy(EE_Parameter.Name, "Beginner\0", 12);
292
        EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
285
        EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
293
}
286
}
294
 
287
 
295
/***************************************************/
288
/***************************************************/
296
/*       Read Parameter from EEPROM as byte        */
289
/*       Read Parameter from EEPROM as byte        */
297
/***************************************************/
290
/***************************************************/
298
uint8_t GetParamByte(uint16_t param_id)
291
uint8_t GetParamByte(uint16_t param_id)
299
{
292
{
300
        return eeprom_read_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + param_id));
293
        return eeprom_read_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + param_id));
301
}
294
}
302
 
295
 
303
/***************************************************/
296
/***************************************************/
304
/*       Write Parameter to EEPROM as byte         */
297
/*       Write Parameter to EEPROM as byte         */
305
/***************************************************/
298
/***************************************************/
306
void SetParamByte(uint16_t param_id, uint8_t value)
299
void SetParamByte(uint16_t param_id, uint8_t value)
307
{
300
{
308
        eeprom_write_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + param_id), value);
301
        eeprom_write_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + param_id), value);
309
}
302
}
310
 
303
 
311
/***************************************************/
304
/***************************************************/
312
/*       Read Parameter from EEPROM as word        */
305
/*       Read Parameter from EEPROM as word        */
313
/***************************************************/
306
/***************************************************/
314
uint16_t GetParamWord(uint16_t param_id)
307
uint16_t GetParamWord(uint16_t param_id)
315
{
308
{
316
        return eeprom_read_word((uint16_t *)(EEPROM_ADR_PARAM_BEGIN + param_id));
309
        return eeprom_read_word((uint16_t *)(EEPROM_ADR_PARAM_BEGIN + param_id));
317
}
310
}
318
 
311
 
319
/***************************************************/
312
/***************************************************/
320
/*       Write Parameter to EEPROM as word         */
313
/*       Write Parameter to EEPROM as word         */
321
/***************************************************/
314
/***************************************************/
322
void SetParamWord(uint16_t param_id, uint16_t value)
315
void SetParamWord(uint16_t param_id, uint16_t value)
323
{
316
{
324
        eeprom_write_word((uint16_t*)(EEPROM_ADR_PARAM_BEGIN + param_id), value);
317
        eeprom_write_word((uint16_t*)(EEPROM_ADR_PARAM_BEGIN + param_id), value);
325
}
318
}
326
 
319
 
327
/***************************************************/
320
/***************************************************/
328
/*       Read Parameter Set from EEPROM            */
321
/*       Read Parameter Set from EEPROM            */
329
/***************************************************/
322
/***************************************************/
330
// number [1..5]
323
// number [1..5]
331
uint8_t ParamSet_ReadFromEEProm(uint8_t setnumber)
324
uint8_t ParamSet_ReadFromEEProm(uint8_t setnumber)
332
{
325
{
333
        uint8_t crc;
326
        uint8_t crc;
334
        uint16_t eeaddr;
327
        uint16_t eeaddr;
335
 
328
 
336
        // range the setnumber
329
        // range the setnumber
337
        if((1 > setnumber) || (setnumber > 5)) setnumber = 3;
330
        if((1 > setnumber) || (setnumber > 5)) setnumber = 3;
338
 
331
 
339
        // calculate eeprom addr
332
        // calculate eeprom addr
340
        eeaddr = EEPROM_ADR_PARAMSET + PARAMSET_STRUCT_LEN * (setnumber - 1);
333
        eeaddr = EEPROM_ADR_PARAMSET + PARAMSET_STRUCT_LEN * (setnumber - 1);
341
 
334
 
342
        // calculate checksum from eeprom
335
        // calculate checksum from eeprom
343
        crc = EEProm_Checksum(eeaddr, PARAMSET_STRUCT_LEN - 1);
336
        crc = EEProm_Checksum(eeaddr, PARAMSET_STRUCT_LEN - 1);
344
 
337
 
345
        // check crc
338
        // check crc
346
        if(crc != eeprom_read_byte((uint8_t*)(eeaddr + PARAMSET_STRUCT_LEN - 1))) return 0;
339
        if(crc != eeprom_read_byte((uint8_t*)(eeaddr + PARAMSET_STRUCT_LEN - 1))) return 0;
347
 
340
 
348
        // check revision
341
        // check revision
349
        if(eeprom_read_byte((uint8_t*)(eeaddr)) != EEPARAM_REVISION) return 0;
342
        if(eeprom_read_byte((uint8_t*)(eeaddr)) != EEPARAM_REVISION) return 0;
350
 
343
 
351
        // read paramset from eeprom
344
        // read paramset from eeprom
352
        eeprom_read_block((void *) &EE_Parameter, (void*)(EEPROM_ADR_PARAMSET + PARAMSET_STRUCT_LEN * (setnumber - 1)), PARAMSET_STRUCT_LEN);
345
        eeprom_read_block((void *) &EE_Parameter, (void*)(EEPROM_ADR_PARAMSET + PARAMSET_STRUCT_LEN * (setnumber - 1)), PARAMSET_STRUCT_LEN);
353
        LED_Init();
346
        LED_Init();
354
        return 1;
347
        return 1;
355
}
348
}
356
 
349
 
357
/***************************************************/
350
/***************************************************/
358
/*        Write Parameter Set to EEPROM            */
351
/*        Write Parameter Set to EEPROM            */
359
/***************************************************/
352
/***************************************************/
360
// number [1..5]
353
// number [1..5]
361
uint8_t ParamSet_WriteToEEProm(uint8_t setnumber)
354
uint8_t ParamSet_WriteToEEProm(uint8_t setnumber)
362
{
355
{
363
        uint8_t crc;
356
        uint8_t crc;
364
 
357
 
365
        if(EE_Parameter.Revision == EEPARAM_REVISION) // write only the right revision to eeprom
358
        if(EE_Parameter.Revision == EEPARAM_REVISION) // write only the right revision to eeprom
366
        {
359
        {
367
                if(setnumber > 5) setnumber = 5;
360
                if(setnumber > 5) setnumber = 5;
368
                if(setnumber < 1) return 0;
361
                if(setnumber < 1) return 0;
369
 
362
 
370
                // update checksum
363
                // update checksum
371
                EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
364
                EE_Parameter.crc = RAM_Checksum((uint8_t*)(&EE_Parameter), sizeof(EE_Parameter)-1);
372
 
365
 
373
                // write paramset to eeprom
366
                // write paramset to eeprom
374
                eeprom_write_block((void *) &EE_Parameter, (void*)(EEPROM_ADR_PARAMSET + PARAMSET_STRUCT_LEN * (setnumber - 1)), PARAMSET_STRUCT_LEN);
367
                eeprom_write_block((void *) &EE_Parameter, (void*)(EEPROM_ADR_PARAMSET + PARAMSET_STRUCT_LEN * (setnumber - 1)), PARAMSET_STRUCT_LEN);
375
 
368
 
376
                // backup channel settings to separate block in eeprom
369
                // backup channel settings to separate block in eeprom
377
                eeprom_write_block( (void*)(EE_Parameter.Kanalbelegung), (void*)(EEPROM_ADR_CHANNELS), sizeof(EE_Parameter.Kanalbelegung));
370
                eeprom_write_block( (void*)(EE_Parameter.Kanalbelegung), (void*)(EEPROM_ADR_CHANNELS), sizeof(EE_Parameter.Kanalbelegung));
378
 
371
 
379
                // write crc of channel block to eeprom
372
                // write crc of channel block to eeprom
380
                crc = RAM_Checksum((uint8_t*)(EE_Parameter.Kanalbelegung), sizeof(EE_Parameter.Kanalbelegung));
373
                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);
374
                eeprom_write_byte((uint8_t*)(EEPROM_ADR_CHANNELS + sizeof(EE_Parameter.Kanalbelegung)), crc);
382
 
375
 
383
                // update active settings number
376
                // update active settings number
384
                SetActiveParamSet(setnumber);
377
                SetActiveParamSet(setnumber);
385
                LED_Init();
378
                LED_Init();
386
                return 1;
379
                return 1;
387
        }
380
        }
388
        // wrong revision
381
        // wrong revision
389
        return 0;
382
        return 0;
390
}
383
}
391
 
384
 
392
/***************************************************/
385
/***************************************************/
393
/*          Read MixerTable from EEPROM            */
386
/*          Read MixerTable from EEPROM            */
394
/***************************************************/
387
/***************************************************/
395
uint8_t MixerTable_ReadFromEEProm(void)
388
uint8_t MixerTable_ReadFromEEProm(void)
396
{
389
{
397
        uint8_t crc;
390
        uint8_t crc;
398
 
391
 
399
        // calculate checksum in eeprom
392
        // calculate checksum in eeprom
400
        crc = EEProm_Checksum(EEPROM_ADR_MIXERTABLE, sizeof(Mixer) - 1);
393
        crc = EEProm_Checksum(EEPROM_ADR_MIXERTABLE, sizeof(Mixer) - 1);
401
 
394
 
402
        // check crc
395
        // check crc
403
        if( crc != eeprom_read_byte((uint8_t*)(EEPROM_ADR_MIXERTABLE + sizeof(Mixer) - 1)) ) return 0;
396
        if( crc != eeprom_read_byte((uint8_t*)(EEPROM_ADR_MIXERTABLE + sizeof(Mixer) - 1)) ) return 0;
404
 
397
 
405
        // check revision
398
        // check revision
406
        if(eeprom_read_byte((uint8_t*)(EEPROM_ADR_MIXERTABLE)) != EEMIXER_REVISION) return 0;
399
        if(eeprom_read_byte((uint8_t*)(EEPROM_ADR_MIXERTABLE)) != EEMIXER_REVISION) return 0;
407
 
400
 
408
        // read mixer table
401
        // read mixer table
409
        eeprom_read_block((void *) &Mixer, (void*)(EEPROM_ADR_MIXERTABLE), sizeof(Mixer));
402
        eeprom_read_block((void *) &Mixer, (void*)(EEPROM_ADR_MIXERTABLE), sizeof(Mixer));
410
        return 1;
403
        return 1;
411
}
404
}
412
 
405
 
413
/***************************************************/
406
/***************************************************/
414
/*          Write Mixer Table to EEPROM            */
407
/*          Write Mixer Table to EEPROM            */
415
/***************************************************/
408
/***************************************************/
416
uint8_t MixerTable_WriteToEEProm(void)
409
uint8_t MixerTable_WriteToEEProm(void)
417
{
410
{
418
        if(Mixer.Revision == EEMIXER_REVISION)
411
        if(Mixer.Revision == EEMIXER_REVISION)
419
        {
412
        {
420
                // update crc
413
                // update crc
421
                Mixer.crc = RAM_Checksum((uint8_t*)(&Mixer), sizeof(Mixer) - 1);
414
                Mixer.crc = RAM_Checksum((uint8_t*)(&Mixer), sizeof(Mixer) - 1);
422
 
415
 
423
                // write to eeprom
416
                // write to eeprom
424
                eeprom_write_block((void *) &Mixer, (void*)(EEPROM_ADR_MIXERTABLE), sizeof(Mixer));
417
                eeprom_write_block((void *) &Mixer, (void*)(EEPROM_ADR_MIXERTABLE), sizeof(Mixer));
425
                return 1;
418
                return 1;
426
        }
419
        }
427
        else return 0;
420
        else return 0;
428
}
421
}
429
 
422
 
430
/***************************************************/
423
/***************************************************/
431
/*    Default Values for Mixer Table               */
424
/*    Default Values for Mixer Table               */
432
/***************************************************/
425
/***************************************************/
433
void MixerTable_Default(void) // Quadro
426
void MixerTable_Default(void) // Quadro
434
{
427
{
435
        uint8_t i;
428
        uint8_t i;
436
 
429
 
437
        Mixer.Revision = EEMIXER_REVISION;
430
        Mixer.Revision = EEMIXER_REVISION;
438
        // clear mixer table
431
        // clear mixer table
439
        for(i = 0; i < 16; i++)
432
        for(i = 0; i < 16; i++)
440
        {
433
        {
441
                Mixer.Motor[i][MIX_GAS]  = 0;
434
                Mixer.Motor[i][MIX_GAS]  = 0;
442
                Mixer.Motor[i][MIX_NICK] = 0;
435
                Mixer.Motor[i][MIX_NICK] = 0;
443
                Mixer.Motor[i][MIX_ROLL] = 0;
436
                Mixer.Motor[i][MIX_ROLL] = 0;
444
                Mixer.Motor[i][MIX_YAW]  = 0;
437
                Mixer.Motor[i][MIX_YAW]  = 0;
445
        }
438
        }
446
        // default = Quadro
439
        // default = Quadro
447
        Mixer.Motor[0][MIX_GAS] = 64; Mixer.Motor[0][MIX_NICK] = +64; Mixer.Motor[0][MIX_ROLL] =   0; Mixer.Motor[0][MIX_YAW] = +64;
440
        Mixer.Motor[0][MIX_GAS] = 64; Mixer.Motor[0][MIX_NICK] = +64; Mixer.Motor[0][MIX_ROLL] =   0; Mixer.Motor[0][MIX_YAW] = +64;
448
        Mixer.Motor[1][MIX_GAS] = 64; Mixer.Motor[1][MIX_NICK] = -64; Mixer.Motor[1][MIX_ROLL] =   0; Mixer.Motor[1][MIX_YAW] = +64;
441
        Mixer.Motor[1][MIX_GAS] = 64; Mixer.Motor[1][MIX_NICK] = -64; Mixer.Motor[1][MIX_ROLL] =   0; Mixer.Motor[1][MIX_YAW] = +64;
449
        Mixer.Motor[2][MIX_GAS] = 64; Mixer.Motor[2][MIX_NICK] =   0; Mixer.Motor[2][MIX_ROLL] = -64; Mixer.Motor[2][MIX_YAW] = -64;
442
        Mixer.Motor[2][MIX_GAS] = 64; Mixer.Motor[2][MIX_NICK] =   0; Mixer.Motor[2][MIX_ROLL] = -64; Mixer.Motor[2][MIX_YAW] = -64;
450
        Mixer.Motor[3][MIX_GAS] = 64; Mixer.Motor[3][MIX_NICK] =   0; Mixer.Motor[3][MIX_ROLL] = +64; Mixer.Motor[3][MIX_YAW] = -64;
443
        Mixer.Motor[3][MIX_GAS] = 64; Mixer.Motor[3][MIX_NICK] =   0; Mixer.Motor[3][MIX_ROLL] = +64; Mixer.Motor[3][MIX_YAW] = -64;
451
        memcpy(Mixer.Name, "Quadro\0", 7);
444
        memcpy(Mixer.Name, "Quadro\0", 7);
452
        Mixer.crc = Mixer.crc = RAM_Checksum((uint8_t*)(&Mixer), sizeof(Mixer) - 1);
445
        Mixer.crc = Mixer.crc = RAM_Checksum((uint8_t*)(&Mixer), sizeof(Mixer) - 1);
453
}
446
}
454
 
447
 
455
/***************************************************/
448
/***************************************************/
456
/*       Get active parameter set                  */
449
/*       Get active parameter set                  */
457
/***************************************************/
450
/***************************************************/
458
uint8_t GetActiveParamSet(void)
451
uint8_t GetActiveParamSet(void)
459
{
452
{
460
        uint8_t setnumber;
453
        uint8_t setnumber;
461
        setnumber = eeprom_read_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + PID_ACTIVE_SET));
454
        setnumber = eeprom_read_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + PID_ACTIVE_SET));
462
        if(setnumber > 5)
455
        if(setnumber > 5)
463
        {
456
        {
464
                setnumber = 3;
457
                setnumber = 3;
465
                eeprom_write_byte((void*)(EEPROM_ADR_PARAM_BEGIN+PID_ACTIVE_SET), setnumber);
458
                eeprom_write_byte((void*)(EEPROM_ADR_PARAM_BEGIN+PID_ACTIVE_SET), setnumber);
466
        }
459
        }
467
        return(setnumber);
460
        return(setnumber);
468
}
461
}
469
 
462
 
470
/***************************************************/
463
/***************************************************/
471
/*       Set active parameter set                  */
464
/*       Set active parameter set                  */
472
/***************************************************/
465
/***************************************************/
473
void SetActiveParamSet(uint8_t setnumber)
466
void SetActiveParamSet(uint8_t setnumber)
474
{
467
{
475
        if(setnumber > 5) setnumber = 5;
468
        if(setnumber > 5) setnumber = 5;
476
        if(setnumber < 1) setnumber = 1;
469
        if(setnumber < 1) setnumber = 1;
477
        eeprom_write_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + PID_ACTIVE_SET), setnumber);
470
        eeprom_write_byte((uint8_t*)(EEPROM_ADR_PARAM_BEGIN + PID_ACTIVE_SET), setnumber);
478
}
471
}
479
 
472
 
480
/***************************************************/
473
/***************************************************/
481
/*       Set default parameter set                 */
474
/*       Set default parameter set                 */
482
/***************************************************/
475
/***************************************************/
483
void SetDefaultParameter(uint8_t set, uint8_t restore_channels)
476
void SetDefaultParameter(uint8_t set, uint8_t restore_channels)
484
{
477
{
485
 
478
 
486
        if(set > 5) set = 5;
479
        if(set > 5) set = 5;
487
        else if(set < 1) set = 1;
480
        else if(set < 1) set = 1;
488
 
481
 
489
        switch(set)
482
        switch(set)
490
        {
483
        {
491
                case 1:
484
                case 1:
492
                        ParamSet_DefaultSet1(); // Fill ParamSet Structure to default parameter set 1 (Sport)
485
                        ParamSet_DefaultSet1(); // Fill ParamSet Structure to default parameter set 1 (Sport)
493
                        break;
486
                        break;
494
                case 2:
487
                case 2:
495
                        ParamSet_DefaultSet2(); // Kamera
488
                        ParamSet_DefaultSet2(); // Kamera
496
                        break;
489
                        break;
497
                case 3:
490
                case 3:
498
                        ParamSet_DefaultSet3(); // Beginner
491
                        ParamSet_DefaultSet3(); // Beginner
499
                        break;
492
                        break;
500
                default:
493
                default:
501
                        ParamSet_DefaultSet3(); // Beginner
494
                        ParamSet_DefaultSet3(); // Beginner
502
                        break;
495
                        break;
503
        }
496
        }
504
        if(restore_channels)
497
        if(restore_channels)
505
        {
498
        {
506
                uint8_t crc;
499
                uint8_t crc;
507
                // 1st check for a valid channel backup in eeprom
500
                // 1st check for a valid channel backup in eeprom
508
                crc = EEProm_Checksum(EEPROM_ADR_CHANNELS, sizeof(EE_Parameter.Kanalbelegung));
501
                crc = EEProm_Checksum(EEPROM_ADR_CHANNELS, sizeof(EE_Parameter.Kanalbelegung));
509
                if(crc == eeprom_read_byte((uint8_t*)(EEPROM_ADR_CHANNELS + sizeof(EE_Parameter.Kanalbelegung))) )
502
                if(crc == eeprom_read_byte((uint8_t*)(EEPROM_ADR_CHANNELS + sizeof(EE_Parameter.Kanalbelegung))) )
510
                {
503
                {
511
                        eeprom_read_block((void *)EE_Parameter.Kanalbelegung, (void*)(EEPROM_ADR_CHANNELS), sizeof(EE_Parameter.Kanalbelegung));
504
                        eeprom_read_block((void *)EE_Parameter.Kanalbelegung, (void*)(EEPROM_ADR_CHANNELS), sizeof(EE_Parameter.Kanalbelegung));
512
                }
505
                }
513
                else ParamSet_DefaultStickMapping();
506
                else ParamSet_DefaultStickMapping();
514
        }
507
        }
515
        else ParamSet_DefaultStickMapping();
508
        else ParamSet_DefaultStickMapping();
516
        ParamSet_WriteToEEProm(set);
509
        ParamSet_WriteToEEProm(set);
517
}
510
}
518
 
511
 
519
/***************************************************/
512
/***************************************************/
520
/*       Initialize EEPROM Parameter Sets          */
513
/*       Initialize EEPROM Parameter Sets          */
521
/***************************************************/
514
/***************************************************/
522
void ParamSet_Init(void)
515
void ParamSet_Init(void)
523
{
516
{
524
        uint8_t channel_backup  = 0, bad_params = 0, ee_default = 0,i;
517
        uint8_t channel_backup  = 0, bad_params = 0, ee_default = 0,i;
525
 
518
 
526
 
519
 
527
        if(EEPARAM_REVISION != GetParamByte(PID_EE_REVISION) )
520
        if(EEPARAM_REVISION != GetParamByte(PID_EE_REVISION) )
528
        {
521
        {
529
                ee_default = 1; // software update or forced by mktool
522
                ee_default = 1; // software update or forced by mktool
530
                SetParamByte(PID_EE_REVISION, EEPARAM_REVISION);
523
                SetParamByte(PID_EE_REVISION, EEPARAM_REVISION);
531
        }
524
        }
532
 
525
 
533
 
526
 
534
        // 1st check for a valid channel backup in eeprom
527
        // 1st check for a valid channel backup in eeprom
535
        i = EEProm_Checksum(EEPROM_ADR_CHANNELS, sizeof(EE_Parameter.Kanalbelegung));
528
        i = EEProm_Checksum(EEPROM_ADR_CHANNELS, sizeof(EE_Parameter.Kanalbelegung));
536
        if(i == eeprom_read_byte((uint8_t*)(EEPROM_ADR_CHANNELS + sizeof(EE_Parameter.Kanalbelegung))) ) channel_backup = 1;
529
        if(i == eeprom_read_byte((uint8_t*)(EEPROM_ADR_CHANNELS + sizeof(EE_Parameter.Kanalbelegung))) ) channel_backup = 1;
537
 
530
 
538
 
531
 
539
        // parameter check
532
        // parameter check
540
 
533
 
541
        // check all 5 parameter settings
534
        // check all 5 parameter settings
542
        for (i = 1;i < 6; i++)
535
        for (i = 1;i < 6; i++)
543
        {
536
        {
544
                if(ee_default || !ParamSet_ReadFromEEProm(i)) // could not read paramset from eeprom
537
                if(ee_default || !ParamSet_ReadFromEEProm(i)) // could not read paramset from eeprom
545
                {
538
                {
546
                        bad_params = 1;
539
                        bad_params = 1;
547
                        printf("\n\rGenerating default Parameter Set %d",i);
540
                        printf("\n\rGenerating default Parameter Set %d",i);
548
                        switch(i)
541
                        switch(i)
549
                        {
542
                        {
550
                                case 1:
543
                                case 1:
551
                                        ParamSet_DefaultSet1(); // Fill ParamSet Structure to default parameter set 1 (Sport)
544
                                        ParamSet_DefaultSet1(); // Fill ParamSet Structure to default parameter set 1 (Sport)
552
                                        break;
545
                                        break;
553
                                case 2:
546
                                case 2:
554
                                        ParamSet_DefaultSet2(); // Kamera
547
                                        ParamSet_DefaultSet2(); // Kamera
555
                                        break;
548
                                        break;
556
                                case 3:
549
                                case 3:
557
                                        ParamSet_DefaultSet3(); // Beginner
550
                                        ParamSet_DefaultSet3(); // Beginner
558
                                        break;
551
                                        break;
559
                                default:
552
                                default:
560
                                        ParamSet_DefaultSet3(); // Kamera
553
                                        ParamSet_DefaultSet3(); // Kamera
561
                                        break;
554
                                        break;
562
                        }
555
                        }
563
                        if(channel_backup) // if we have an channel mapping backup in eeprom
556
                        if(channel_backup) // if we have an channel mapping backup in eeprom
564
                        {       // restore it from eeprom
557
                        {       // restore it from eeprom
565
                                eeprom_read_block((void *)EE_Parameter.Kanalbelegung, (void*)(EEPROM_ADR_CHANNELS), sizeof(EE_Parameter.Kanalbelegung));
558
                                eeprom_read_block((void *)EE_Parameter.Kanalbelegung, (void*)(EEPROM_ADR_CHANNELS), sizeof(EE_Parameter.Kanalbelegung));
566
                        }
559
                        }
567
                        else
560
                        else
568
                        {       // use default mapping
561
                        {       // use default mapping
569
                                ParamSet_DefaultStickMapping();
562
                                ParamSet_DefaultStickMapping();
570
                        }
563
                        }
571
                        ParamSet_WriteToEEProm(i);
564
                        ParamSet_WriteToEEProm(i);
572
                }
565
                }
573
        }
566
        }
574
        if(bad_params) // at least one of the parameter settings were invalid
567
        if(bad_params) // at least one of the parameter settings were invalid
575
        {
568
        {
576
                // default-Setting is parameter set 3
569
                // default-Setting is parameter set 3
577
                SetActiveParamSet(3);
570
                SetActiveParamSet(3);
578
        }
571
        }
579
 
572
 
580
 
573
 
581
        // read active parameter set to ParamSet stucture
574
        // read active parameter set to ParamSet stucture
582
        i = GetActiveParamSet();
575
        i = GetActiveParamSet();
583
        ParamSet_ReadFromEEProm(i);
576
        ParamSet_ReadFromEEProm(i);
584
        printf("\n\rUsing Parameter Set %d", i);
577
        printf("\n\rUsing Parameter Set %d", i);
585
 
578
 
586
        // load mixer table
579
        // load mixer table
587
        if(ee_default || !MixerTable_ReadFromEEProm() )
580
        if(ee_default || !MixerTable_ReadFromEEProm() )
588
        {
581
        {
589
                printf("\n\rGenerating default Mixer Table");
582
                printf("\n\rGenerating default Mixer Table");
590
                MixerTable_Default(); // Quadro
583
                MixerTable_Default(); // Quadro
591
                MixerTable_WriteToEEProm();
584
                MixerTable_WriteToEEProm();
592
        }
585
        }
593
        // determine motornumber
586
        // determine motornumber
594
        RequiredMotors = 0;
587
        RequiredMotors = 0;
595
        for(i = 0; i < 16; i++)
588
        for(i = 0; i < 16; i++)
596
        {
589
        {
597
                if(Mixer.Motor[i][MIX_GAS] > 0) RequiredMotors++;
590
                if(Mixer.Motor[i][MIX_GAS] > 0) RequiredMotors++;
598
        }
591
        }
599
 
592
 
600
        printf("\n\rMixer-Config: '%s' (%u Motors)",Mixer.Name, RequiredMotors);
593
        printf("\n\rMixer-Config: '%s' (%u Motors)",Mixer.Name, RequiredMotors);
601
        printf("\n\r==============================");
594
        printf("\n\r==============================");
602
}
595
}
603
 
596