Subversion Repositories NaviCtrl

Rev

Rev 27 | Rev 41 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
1 ingob 1
/*#######################################################################################*/
2
/* !!! THIS IS NOT FREE SOFTWARE !!!                                                     */
3
/*#######################################################################################*/
4
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
5
// + Copyright (c) 2008 Ingo Busker, Holger Buss
6
// + Nur für den privaten Gebrauch
7
// + FOR NON COMMERCIAL USE ONLY
8
// + www.MikroKopter.com
9
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
10
// + Es gilt für das gesamte Projekt (Hardware, Software, Binärfiles, Sourcecode und Dokumentation), 
11
// + dass eine Nutzung (auch auszugsweise) nur für den privaten (nicht-kommerziellen) Gebrauch zulässig ist. 
12
// + Sollten direkte oder indirekte kommerzielle Absichten verfolgt werden, ist mit uns (info@mikrokopter.de) Kontakt 
13
// + bzgl. der Nutzungsbedingungen aufzunehmen. 
14
// + Eine kommerzielle Nutzung ist z.B.Verkauf von MikroKoptern, Bestückung und Verkauf von Platinen oder Bausätzen,
15
// + Verkauf von Luftbildaufnahmen, usw.
16
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
17
// + Werden Teile des Quellcodes (mit oder ohne Modifikation) weiterverwendet oder veröffentlicht, 
18
// + unterliegen sie auch diesen Nutzungsbedingungen und diese Nutzungsbedingungen incl. Copyright müssen dann beiliegen
19
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
20
// + Sollte die Software (auch auszugesweise) oder sonstige Informationen des MikroKopter-Projekts
21
// + auf anderen Webseiten oder sonstigen Medien veröffentlicht werden, muss unsere Webseite "http://www.mikrokopter.de"
22
// + eindeutig als Ursprung verlinkt werden
23
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
24
// + Keine Gewähr auf Fehlerfreiheit, Vollständigkeit oder Funktion
25
// + Benutzung auf eigene Gefahr
26
// + Wir übernehmen keinerlei Haftung für direkte oder indirekte Personen- oder Sachschäden
27
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
28
// + Die PORTIERUNG der Software (oder Teile davon) auf andere Systeme (ausser der Hardware von www.mikrokopter.de) ist nur 
29
// + mit unserer Zustimmung zulässig
30
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
31
// + Teile, die nicht eindeutig mit unserer Lizenzvereinbarung gekennzeichnet sind, unterliegen u.U. eigenen Vereinbarungen:
32
// + z.B. Die Funktion printf_P() unterliegt ihrer eigenen Lizenz 
33
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
34
// + Redistributions of source code (with or without modifications) must retain the above copyright notice, 
35
// + this list of conditions and the following disclaimer.
36
// +   * Neither the name of the copyright holders nor the names of contributors may be used to endorse or promote products derived
37
// +     from this software without specific prior written permission.
38
// +   * The use of this project (hardware, software, binary files, sources and documentation) is only permitted 
39
// +     for non-commercial use (directly or indirectly)
40
// +     Commercial use (for excample: selling of MikroKopters, selling of PCBs, assembly, ...) is only permitted 
41
// +     with our written permission
42
// +   * If sources or documentations are redistributet on other webpages, out webpage (http://www.MikroKopter.de) must be 
43
// +     clearly linked as origin 
44
// +   * PORTING this software (or part of it) to systems (other than hardware from www.mikrokopter.de) is NOT allowed
45
//
46
// +  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
47
// +  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
48
// +  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
49
// +  ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
50
// +  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
51
// +  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
52
// +  SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
53
// +  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
54
// +  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
55
// +  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
56
// +  POSSIBILITY OF SUCH DAMAGE. 
57
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
58
const unsigned long _Main_Crystal = 25000;
59
 
60
#include "main.h"
24 StephanB 61
#include "kml.h"
1 ingob 62
 
63
u32 TimerCompassUpdate;
64
u32 TimerI2CReadDelay;
65
u32 TimerDebugDataDelay;
24 StephanB 66
u32 KmlAddPointDelay;
1 ingob 67
 
68
u8 BeepTime;
69
void Init_Undef(void);
70
u8 Parameter_UserParam1;
71
u8 Parameter_UserParam2;
72
u8 Parameter_UserParam3;
73
u8 Parameter_UserParam4;
74
u8 Parameter_UserParam5;
75
u8 Parameter_UserParam6;
76
u8 Parameter_UserParam7;
77
u8 Parameter_UserParam8;
27 holgerb 78
//++++++++++++++++++++++++++++++++++++++++++++++++++
1 ingob 79
s32 FC_StickNick;
80
s32 FC_StickRoll;
81
s32 FC_StickGier;
82
s32 FC_StickGas;
83
s32 FC_Poti1;
84
s32 FC_Poti2;
85
s32 FC_Poti3;
86
s32 FC_Poti4;
27 holgerb 87
//++++++++++++++++++++++++++++++++++++++++++++++++++
1 ingob 88
s32 SenderOkay = 0;
27 holgerb 89
s32 UBat = 0;
90
s32 UndervoltageLevel = 0;
91
s32 ActiveSetting = 1;
92
//++++++++++++++++++++++++++++++++++++++++++++++++++
93
s32 Parameter_NaviGpsModeControl = 128;
94
s32 Parameter_NaviGpsGain = 0;
95
s32 Parameter_NaviGpsP = 90;
96
s32 Parameter_NaviGpsI = 0;
97
s32 Parameter_NaviGpsD = 90;
98
s32 Parameter_NaviGpsACC = 0;
99
s32 Parameter_NaviGpsMinSat = 3;
100
s32 Parameter_NaviStickThreshold = 8;
101
s32 Parameter_RadiusAlert = 15;
102
//++++++++++++++++++++++++++++++++++++++++++++++++++
103
#define FLAG_MOTOR_RUN  1
104
#define FLAG_FLY        2
105
#define FLAG_CALIBRATE  4
106
#define FLAG_START      8
107
u32 MikroKopterFlags;
108
u32 ClearFlags = 1;
109
//++++++++++++++++++++++++++++++++++++++++++++++++++
1 ingob 110
u8 text[20];
111
 
112
//----------------------------------------------------------------------------------------------------
113
void Leds_Init(void)
114
{
115
    GPIO_InitTypeDef GPIO_InitStructure;
116
 
117
        SCU_APBPeriphClockConfig(__GPIO6, ENABLE);      
118
    SCU_APBPeriphClockConfig(__GPIO5, ENABLE);  
119
 
120
        //GPIO_DeInit(GPIO5);
121
    GPIO_InitStructure.GPIO_Direction = GPIO_PinOutput;
122
    GPIO_InitStructure.GPIO_Pin =               GPIO_Pin_6 | GPIO_Pin_7;
123
    GPIO_InitStructure.GPIO_Type =              GPIO_Type_PushPull ;
124
    GPIO_InitStructure.GPIO_Alternate = GPIO_OutputAlt1  ;
125
    GPIO_Init(GPIO5, &GPIO_InitStructure);
126
 
24 StephanB 127
        //SD_SWITCH
1 ingob 128
    GPIO_InitStructure.GPIO_Direction = GPIO_PinInput;
129
    GPIO_InitStructure.GPIO_Pin =               GPIO_Pin_3;
130
    GPIO_InitStructure.GPIO_Type =              GPIO_Type_PushPull;
131
    GPIO_InitStructure.GPIO_Alternate = GPIO_InputAlt1;
132
    GPIO_Init(GPIO5, &GPIO_InitStructure);
133
 
134
}
135
  //
136
void OutputStartupData(void)
137
{
138
 
24 StephanB 139
   char tex[20];
1 ingob 140
   SerialPutString("\n\r--------------\n\r");
141
 
142
   sprintf(text,"NaviCtrl V%d.%d\n\r",  VersionInfo.Hauptversion,  VersionInfo.Nebenversion); SerialPutString(text);
143
 
144
 
145
}
146
 
147
//----------------------------------------------------------------------------------------------------
148
int main(void)
149
{
150
   static u8 oldCompassCalState = 0;
151
 
24 StephanB 152
 
153
   static u8 kml_state = 0;
154
   u8 kml_cnt = 0;
155
   KML_Document_t       mydocument;
156
   File *file1;
157
 
158
 
159
   u8 str[80];
160
 
161
 
162
   KML_DocumentInit(&mydocument);                                       // Initialise the new kml-document for further use.     
163
 
164
 
1 ingob 165
  // SCU_MCLKSourceConfig(SCU_MCLK_OSC);
166
  // SCU_PCLKDivisorConfig(SCU_PCLK_Div2);
167
  // SCU_MCLKSourceConfig(SCU_MCLK_PLL);
168
 
169
 
170
   SCU_MCLKSourceConfig(SCU_MCLK_OSC);
171
   SCU_PLLCmd(DISABLE); // PLL aus 
172
   SCU_RCLKDivisorConfig(SCU_RCLK_Div1);
173
   SCU_HCLKDivisorConfig(SCU_HCLK_Div1);
174
   SCU_PCLKDivisorConfig(SCU_PCLK_Div2);
175
  // SCU_FMICLKDivisorConfig(SCU_FMICLK_Div1);
176
  // FMI_Config(FMI_READ_WAIT_STATE_3,FMI_WRITE_WAIT_STATE_0, FMI_PWD_ENABLE, FMI_LVD_ENABLE,FMI_FREQ_HIGH);
177
   SCU_PLLFactorsConfig(192,25,3); // PLL = 48 MHz 
178
 
179
   SCU_PLLCmd(ENABLE); // PLL Enabled 
180
 
181
   SCU_MCLKSourceConfig(SCU_MCLK_PLL); // MCLK = PLL 
182
 
183
 
184
   VersionInfo.Hauptversion = VERSION_HAUPTVERSION;
185
   VersionInfo.Nebenversion = VERSION_NEBENVERSION;
186
   VersionInfo.PCKompatibel = VERSION_KOMPATIBEL;
187
 
188
   SCU_AHBPeriphClockConfig(__VIC,ENABLE);
189
   SCU_AHBPeriphReset(__VIC,DISABLE);
190
   VIC_DeInit();
191
 
192
   InitInterrupt();
193
 
194
   Leds_Init();
195
   Debug_UART1_Init();
196
   OutputStartupData();
197
 
198
   GPS_UART0_Init();
199
   USB_ConfigInit();
200
 
201
 
202
   SPI0_Init();
203
 
204
 
205
 
206
   TIMER1_Init();
207
   I2C1_Init();
208
 
209
   I2C_Version.Hauptversion = 0xff;
210
 
211
   SendI2C_Command(I2C_CMD_VERSION);
212
 
213
   TimerCompassUpdate = SetDelay(50);
214
   while (!CheckDelay(TimerCompassUpdate));
215
 
216
   TimerCompassUpdate = SetDelay(5);
217
   TimerI2CReadDelay = SetDelay(5);
218
 
24 StephanB 219
   KmlAddPointDelay = SetDelay(250);
220
 
221
 
222
   SerialPutString("\r\n---------------------------------------------");
223
 
224
 
225
//   ReadSetting(1); 
226
   SerialPutString("\r\n---------------------------------------------\r\n\r\n");
227
 
1 ingob 228
   InitFat16();
24 StephanB 229
 
1 ingob 230
 
231
   for (;;)
232
   {
233
    if(NeuerDatensatzEmpfangen)
234
          {
235
                 BearbeiteRxDaten();
236
             DatenUebertragung();
237
//               if (GPIO_ReadBit(GPIO5, GPIO_Pin_3)) SerialPutString("keine SD\n\r");    else SerialPutString("SD eingesteckt!\n\r");
238
 
239
      }
240
 
241
 
242
          UpdateSPI_Buffer();
243
          SPI_CheckSlaveSelect();
244
          UART1_Transmit();
245
 
246
   // ----------- I2C Timing -------------------------
247
          if (CheckDelay(TimerCompassUpdate))
248
          {
249
                if(oldCompassCalState != CompassCalState)
250
                  {
251
                    oldCompassCalState = CompassCalState;
252
                    TimerCompassUpdate = SetDelay(25);
253
            SendI2C_Command(I2C_CMD_WRITE_CAL);
254
                  }
255
                  else
256
                  {
257
                   GPIO_ToggleBit(GPIO5, GPIO_Pin_6);
258
                   GPIO_ToggleBit(GPIO5, GPIO_Pin_7);
259
               TimerCompassUpdate = SetDelay(25);
260
           SendI2C_Command(I2C_CMD_READ_HEADING);
261
                  }
262
 
263
           }
264
 
265
          if (CheckDelay(TimerI2CReadDelay))
266
          {
267
            if (I2C_ReadRequest)
268
                {
269
                  I2C_ReadRequest= 0;
270
 
271
                  I2C_Direction = I2C_MODE_RECEIVER;
272
                  I2C_GenerateStart(I2C1, ENABLE);
273
                }
274
                TimerI2CReadDelay = SetDelay(1000);
275
          }
276
 
277
          if (CheckDelay(TimerDebugDataDelay))
278
          {  SendGPSPosAnforderung = 1;
279
         DatenUebertragung();
280
 
281
             TimerDebugDataDelay = SetDelay(500);
282
          }
24 StephanB 283
 
284
 
285
   // ----------- KML Timing -------------------------
39 holgerb 286
          if(CheckDelay(KmlAddPointDelay) && 0)
24 StephanB 287
          {
288
                KmlAddPointDelay = SetDelay(500);
289
                switch(kml_state)
290
                {
291
                        case 0:
292
                                if((GPS_Data.Flags & GPS_FIX) && (GPS_Data.Used_Sat >= GPS_SAT_MIN))
293
                                {
294
                                        if(str_Volume.state == INITIALIZED)                                                                                     // has the volume and filesystem been initialized?
295
                                        {
296
                                                if(KML_DocumentOpen("flight01.kml",&mydocument))                                                // create a new kml-document on the memorycard.
297
                                                {
298
                                                        SerialPutString("\r\nopening kml-file\r\nadding data");
299
                                                        kml_state = 1;
300
                                                }
301
                                        }
302
                                        else
303
                                        {
304
                                                InitFat16();
27 holgerb 305
                                                if(str_Volume.state != INITIALIZED) KmlAddPointDelay = SetDelay(5000);  // try again in 5 sek
24 StephanB 306
                                        }
307
                                }
308
                        break;                                                                                                                                                          // document.state will be changed to DOC_OPENED automatic.
309
 
310
                        case 1:                                                                                                                                                         // linestring opened, so datapoint (gps_coordinates) can be added to the document.
311
                                if(kml_cnt++ < 20)                                                                                                                              // add 10 datapoints to the document.
312
                                {
313
                                        KML_LoggGPSCoordinates(GPS_Data,&mydocument);
314
                                }
315
                                else                                                                                                                                                    // after the datapoints have been written to the document close the document.
316
                                {
317
                                        KML_DocumentClose(&mydocument);                                                
318
                                        SerialPutString("\r\nfile closed");
319
                                        kml_state = 2;
320
                                }
321
                        break;
322
 
323
                        default:                                                                                                                                                        // all data has been written to card. open new document to add new data.
324
                }
325
          }
326
        }
1 ingob 327
}
328
 
24 StephanB 329
 
330