Subversion Repositories NaviCtrl

Rev

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

Rev 291 Rev 295
1
/*#######################################################################################*/
1
/*#######################################################################################*/
2
/* !!! THIS IS NOT FREE SOFTWARE !!!                                                     */
2
/* !!! THIS IS NOT FREE SOFTWARE !!!                                                     */
3
/*#######################################################################################*/
3
/*#######################################################################################*/
4
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
4
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
5
// + Copyright (c) 2008 Ingo Busker, Holger Buss
5
// + Copyright (c) 2008 Ingo Busker, Holger Buss
6
// + Nur für den privaten Gebrauch / NON-COMMERCIAL USE ONLY
6
// + Nur für den privaten Gebrauch / NON-COMMERCIAL USE ONLY
7
// + FOR NON COMMERCIAL USE ONLY
7
// + FOR NON COMMERCIAL USE ONLY
8
// + www.MikroKopter.com
8
// + www.MikroKopter.com
9
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
9
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
10
// + Es gilt für das gesamte Projekt (Hardware, Software, Binärfiles, Sourcecode und Dokumentation),
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.
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
12
// + Sollten direkte oder indirekte kommerzielle Absichten verfolgt werden, ist mit uns (info@mikrokopter.de) Kontakt
13
// + bzgl. der Nutzungsbedingungen aufzunehmen.
13
// + bzgl. der Nutzungsbedingungen aufzunehmen.
14
// + Eine kommerzielle Nutzung ist z.B.Verkauf von MikroKoptern, Bestückung und Verkauf von Platinen oder Bausätzen,
14
// + Eine kommerzielle Nutzung ist z.B.Verkauf von MikroKoptern, Bestückung und Verkauf von Platinen oder Bausätzen,
15
// + Verkauf von Luftbildaufnahmen, usw.
15
// + Verkauf von Luftbildaufnahmen, usw.
16
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
16
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
17
// + Werden Teile des Quellcodes (mit oder ohne Modifikation) weiterverwendet oder veröffentlicht,
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
18
// + unterliegen sie auch diesen Nutzungsbedingungen und diese Nutzungsbedingungen incl. Copyright müssen dann beiliegen
19
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
19
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
20
// + Sollte die Software (auch auszugesweise) oder sonstige Informationen des MikroKopter-Projekts
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"
21
// + auf anderen Webseiten oder sonstigen Medien veröffentlicht werden, muss unsere Webseite "http://www.mikrokopter.de"
22
// + eindeutig als Ursprung verlinkt werden
22
// + eindeutig als Ursprung verlinkt werden
23
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
23
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
24
// + Keine Gewähr auf Fehlerfreiheit, Vollständigkeit oder Funktion
24
// + Keine Gewähr auf Fehlerfreiheit, Vollständigkeit oder Funktion
25
// + Benutzung auf eigene Gefahr
25
// + Benutzung auf eigene Gefahr
26
// + Wir übernehmen keinerlei Haftung für direkte oder indirekte Personen- oder Sachschäden
26
// + Wir übernehmen keinerlei Haftung für direkte oder indirekte Personen- oder Sachschäden
27
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
27
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
28
// + Die Portierung oder Nutzung der Software (oder Teile davon) auf andere Systeme (ausser der Hardware von www.mikrokopter.de) ist nur
28
// + Die Portierung oder Nutzung der Software (oder Teile davon) auf andere Systeme (ausser der Hardware von www.mikrokopter.de) ist nur
29
// + mit unserer Zustimmung zulässig
29
// + mit unserer Zustimmung zulässig
30
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
30
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
31
// + Die Funktion printf_P() unterliegt ihrer eigenen Lizenz und ist hiervon nicht betroffen
31
// + Die Funktion printf_P() unterliegt ihrer eigenen Lizenz und ist hiervon nicht betroffen
32
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
32
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
33
// + Redistributions of source code (with or without modifications) must retain the above copyright notice,
33
// + Redistributions of source code (with or without modifications) must retain the above copyright notice,
34
// + this list of conditions and the following disclaimer.
34
// + this list of conditions and the following disclaimer.
35
// +   * Neither the name of the copyright holders nor the names of contributors may be used to endorse or promote products derived
35
// +   * Neither the name of the copyright holders nor the names of contributors may be used to endorse or promote products derived
36
// +     from this software without specific prior written permission.
36
// +     from this software without specific prior written permission.
37
// +   * The use of this project (hardware, software, binary files, sources and documentation) is only permitted
37
// +   * The use of this project (hardware, software, binary files, sources and documentation) is only permitted
38
// +     for non-commercial use (directly or indirectly)
38
// +     for non-commercial use (directly or indirectly)
39
// +     Commercial use (for excample: selling of MikroKopters, selling of PCBs, assembly, ...) is only permitted
39
// +     Commercial use (for excample: selling of MikroKopters, selling of PCBs, assembly, ...) is only permitted
40
// +     with our written permission
40
// +     with our written permission
41
// +   * If sources or documentations are redistributet on other webpages, out webpage (http://www.MikroKopter.de) must be
41
// +   * If sources or documentations are redistributet on other webpages, out webpage (http://www.MikroKopter.de) must be
42
// +     clearly linked as origin
42
// +     clearly linked as origin
43
// +   * porting the sources to other systems or using the software on other systems (except hardware from www.mikrokopter.de) is not allowed
43
// +   * porting the sources to other systems or using the software on other systems (except hardware from www.mikrokopter.de) is not allowed
44
//
44
//
45
// +  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
45
// +  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
46
// +  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
46
// +  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
47
// +  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
47
// +  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
48
// +  ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
48
// +  ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
49
// +  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
49
// +  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
50
// +  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
50
// +  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
51
// +  SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
51
// +  SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
52
// +  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
52
// +  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
53
// +  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
53
// +  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
54
// +  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
54
// +  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
55
// +  POSSIBILITY OF SUCH DAMAGE.
55
// +  POSSIBILITY OF SUCH DAMAGE.
56
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
56
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
57
#include <stdio.h>
57
#include <stdio.h>
58
#include <stdarg.h>
58
#include <stdarg.h>
59
#include <string.h>
59
#include <string.h>
60
 
60
 
61
#include "91x_lib.h"
61
#include "91x_lib.h"
62
#include "main.h"
62
#include "main.h"
63
#include "config.h"
63
#include "config.h"
64
#include "menu.h"
64
#include "menu.h"
65
#include "GPS.h"
65
#include "GPS.h"
66
#include "i2c.h"
66
#include "i2c.h"
67
#include "uart0.h"
67
#include "uart0.h"
68
#include "uart1.h"
68
#include "uart1.h"
69
#include "uart2.h"
69
#include "uart2.h"
70
#include "timer1.h"
70
#include "timer1.h"
71
#include "timer2.h"
71
#include "timer2.h"
72
#include "analog.h"
72
#include "analog.h"
73
#include "compass.h"
73
#include "compass.h"
74
#include "waypoints.h"
74
#include "waypoints.h"
75
#include "mkprotocol.h"
75
#include "mkprotocol.h"
76
#include "params.h"
76
#include "params.h"
77
#include "fifo.h"
77
#include "fifo.h"
78
#include "debug.h" 
78
#include "debug.h" 
79
 
79
 
80
#define FALSE   0
80
#define FALSE   0
81
#define TRUE    1
81
#define TRUE    1
82
 
82
 
83
#define ABO_TIMEOUT 4000 // disable abo after 4 seconds
83
#define ABO_TIMEOUT 4000 // disable abo after 4 seconds
84
u32 UART1_AboTimeOut = 0;
84
u32 UART1_AboTimeOut = 0;
85
 
85
 
86
u8 UART1_Request_VersionInfo    = FALSE;
86
u8 UART1_Request_VersionInfo    = FALSE;
87
u8 UART1_Request_ExternalControl= FALSE;
87
u8 UART1_Request_ExternalControl= FALSE;
88
u8 UART1_Request_Display                = FALSE;
88
u8 UART1_Request_Display                = FALSE;
89
u8 UART1_Request_Display1               = FALSE;
89
u8 UART1_Request_Display1               = FALSE;
90
u8 UART1_Request_DebugData              = FALSE;
90
u8 UART1_Request_DebugData              = FALSE;
91
u8 UART1_Request_DebugLabel             = 255;
91
u8 UART1_Request_DebugLabel             = 255;
92
u8 UART1_Request_NaviData               = FALSE;
92
u8 UART1_Request_NaviData               = FALSE;
93
u8 UART1_Request_ErrorMessage   = FALSE;
93
u8 UART1_Request_ErrorMessage   = FALSE;
94
u8 UART1_Request_NewPoint               = FALSE;
94
u8 UART1_Request_WritePoint             = 0xFF;
95
u8 UART1_Request_ReadPoint              = 0;
95
u8 UART1_Request_ReadPoint              = 0;
96
u8 UART1_Request_Data3D             = FALSE;
96
u8 UART1_Request_Data3D             = FALSE;
97
u8 UART1_Request_Echo               = FALSE;
97
u8 UART1_Request_Echo               = FALSE;
98
u8 UART1_Request_ParameterId    = 0;
98
u8 UART1_Request_ParameterId    = 0;
99
u8 UART1_Request_Parameter              = FALSE;
99
u8 UART1_Request_Parameter              = FALSE;
100
u8 UART1_DisplayKeys                    = 0;
100
u8 UART1_DisplayKeys                    = 0;
101
u8 UART1_DisplayLine                    = 0;
101
u8 UART1_DisplayLine                    = 0;
102
u8 UART1_ConfirmFrame                   = 0;
102
u8 UART1_ConfirmFrame                   = 0;
103
 
103
 
104
UART_TypeDef *DebugUART = UART1;
104
UART_TypeDef *DebugUART = UART1;
105
 
105
 
106
// the primary rx fifo
106
// the primary rx fifo
107
#define UART1_RX_FIFO_LEN 512
107
#define UART1_RX_FIFO_LEN 512
108
u8 UART1_rxfifobuffer[UART1_RX_FIFO_LEN];
108
u8 UART1_rxfifobuffer[UART1_RX_FIFO_LEN];
109
fifo_t UART1_rx_fifo;
109
fifo_t UART1_rx_fifo;
110
 
110
 
111
// the rx buffer
111
// the rx buffer
112
#define UART1_RX_BUFFER_LEN  150
112
#define UART1_RX_BUFFER_LEN  150
113
u8 UART1_rbuffer[UART1_RX_BUFFER_LEN];
113
u8 UART1_rbuffer[UART1_RX_BUFFER_LEN];
114
Buffer_t UART1_rx_buffer;
114
Buffer_t UART1_rx_buffer;
115
 
115
 
116
// the tx buffer
116
// the tx buffer
117
#define UART1_TX_BUFFER_LEN  150
117
#define UART1_TX_BUFFER_LEN  150
118
u8 UART1_tbuffer[UART1_TX_BUFFER_LEN];
118
u8 UART1_tbuffer[UART1_TX_BUFFER_LEN];
119
Buffer_t UART1_tx_buffer;
119
Buffer_t UART1_tx_buffer;
120
 
120
 
121
 
121
 
122
 
122
 
123
volatile u8 SerialLinkOkay = 0;
123
volatile u8 SerialLinkOkay = 0;
124
 
124
 
125
u8 text[200];
125
u8 text[200];
126
 
126
 
127
const u8 ANALOG_LABEL[32][16] =
127
const u8 ANALOG_LABEL[32][16] =
128
{
128
{
129
   //1234567890123456
129
   //1234567890123456
130
        "AngleNick       ", //0
130
        "AngleNick       ", //0
131
        "AngleRoll       ",
131
        "AngleRoll       ",
132
        "AccNick         ",
132
        "AccNick         ",
133
        "AccRoll         ",
133
        "AccRoll         ",
134
        "OperatingRadius ",
134
        "OperatingRadius ",
135
        "FC-Flags        ", //5
135
        "FC-Flags        ", //5
136
        "NC-Flags        ",
136
        "NC-Flags        ",
137
        "NickServo       ",
137
        "NickServo       ",
138
        "RollServo       ",
138
        "RollServo       ",
139
        "GPS Data        ",
139
        "GPS Data        ",
140
        "CompassHeading  ", //10
140
        "CompassHeading  ", //10
141
        "GyroHeading     ",
141
        "GyroHeading     ",
142
        "SPI Error       ",
142
        "SPI Error       ",
143
        "SPI Okay        ",
143
        "SPI Okay        ",
144
        "I2C Error       ",
144
        "I2C Error       ",
145
        "I2C Okay        ", //15
145
        "I2C Okay        ", //15
146
        "*POI_INDEX      ",//    "Kalman_K        ",
146
        "*POI_INDEX      ",//    "Kalman_K        ",
147
        "ACC_Speed_N     ",
147
        "ACC_Speed_N     ",
148
        "ACC_Speed_E     ",
148
        "ACC_Speed_E     ",
149
        "Speed_z         ",//    "GPS ACC         ",
149
        "Speed_z         ",//    "GPS ACC         ",
150
        "*DesiredAltitude",//20
150
        "*DesiredAltitude",//20
151
        "N_Speed         ",
151
        "N_Speed         ",
152
        "E_Speed         ",
152
        "E_Speed         ",
153
        "*POI_ALTITUDE   ",
153
        "*POI_ALTITUDE   ",
154
        "*MY_Altitude    ",
154
        "*MY_Altitude    ",
155
        "*AltitudeSpeed  ",//25
155
        "*AltitudeSpeed  ",//25
156
        "*CAM-Azimut     ",
156
        "*CAM-Azimut     ",
157
        "Distance N      ",
157
        "Distance N      ",
158
        "Distance E      ",
158
        "Distance E      ",
159
        "GPS_Nick        ",
159
        "GPS_Nick        ",
160
        "GPS_Roll        ", //30
160
        "GPS_Roll        ", //30
161
        "Used_Sats       "
161
        "Used_Sats       "
162
};
162
};
163
 
163
 
164
DebugOut_t DebugOut;
164
DebugOut_t DebugOut;
165
ExternControl_t ExternControl;
165
ExternControl_t ExternControl;
166
UART_VersionInfo_t UART_VersionInfo;
166
UART_VersionInfo_t UART_VersionInfo;
167
NaviData_t NaviData;
167
NaviData_t NaviData;
168
Data3D_t Data3D;
168
Data3D_t Data3D;
169
u16 Echo; // 2 bytes recieved will be sent back as echo
169
u16 Echo; // 2 bytes recieved will be sent back as echo
170
 
170
 
171
u32 UART1_DebugData_Timer = 0;
171
u32 UART1_DebugData_Timer = 0;
172
u32 UART1_DebugData_Interval = 0;       // in ms
172
u32 UART1_DebugData_Interval = 0;       // in ms
173
u32 UART1_NaviData_Timer = 0;
173
u32 UART1_NaviData_Timer = 0;
174
u32 UART1_NaviData_Interval = 0;        // in ms
174
u32 UART1_NaviData_Interval = 0;        // in ms
175
u32 UART1_Data3D_Timer = 0;
175
u32 UART1_Data3D_Timer = 0;
176
u32 UART1_Data3D_Interval = 0;          // in ms
176
u32 UART1_Data3D_Interval = 0;          // in ms
177
u32 UART1_Display_Timer = 0;
177
u32 UART1_Display_Timer = 0;
178
u32 UART1_Display_Interval = 0;         // in ms
178
u32 UART1_Display_Interval = 0;         // in ms
179
 
179
 
180
/********************************************************/
180
/********************************************************/
181
/*            Initialization the UART1                  */
181
/*            Initialization the UART1                  */
182
/********************************************************/
182
/********************************************************/
183
void UART1_Init (void)
183
void UART1_Init (void)
184
{
184
{
185
        GPIO_InitTypeDef GPIO_InitStructure;
185
        GPIO_InitTypeDef GPIO_InitStructure;
186
        UART_InitTypeDef UART_InitStructure;
186
        UART_InitTypeDef UART_InitStructure;
187
 
187
 
188
        // initialize txd buffer
188
        // initialize txd buffer
189
        Buffer_Init(&UART1_tx_buffer, UART1_tbuffer, UART1_TX_BUFFER_LEN);
189
        Buffer_Init(&UART1_tx_buffer, UART1_tbuffer, UART1_TX_BUFFER_LEN);
190
 
190
 
191
        // initialize rxd buffer
191
        // initialize rxd buffer
192
        Buffer_Init(&UART1_rx_buffer, UART1_rbuffer, UART1_RX_BUFFER_LEN);
192
        Buffer_Init(&UART1_rx_buffer, UART1_rbuffer, UART1_RX_BUFFER_LEN);
193
 
193
 
194
        // initialize the rx fifo, block UART IRQ geting a byte from fifo
194
        // initialize the rx fifo, block UART IRQ geting a byte from fifo
195
        fifo_init(&UART1_rx_fifo, UART1_rxfifobuffer, UART1_RX_FIFO_LEN, NO_ITLine, UART1_ITLine);
195
        fifo_init(&UART1_rx_fifo, UART1_rxfifobuffer, UART1_RX_FIFO_LEN, NO_ITLine, UART1_ITLine);
196
 
196
 
197
        SCU_APBPeriphClockConfig(__UART1, ENABLE);  // Enable the UART1 Clock
197
        SCU_APBPeriphClockConfig(__UART1, ENABLE);  // Enable the UART1 Clock
198
        SCU_APBPeriphClockConfig(__GPIO3, ENABLE);  // Enable the GPIO3 Clock
198
        SCU_APBPeriphClockConfig(__GPIO3, ENABLE);  // Enable the GPIO3 Clock
199
 
199
 
200
        /*Configure UART1_Rx pin GPIO3.2*/
200
        /*Configure UART1_Rx pin GPIO3.2*/
201
        GPIO_StructInit(&GPIO_InitStructure);
201
        GPIO_StructInit(&GPIO_InitStructure);
202
        GPIO_InitStructure.GPIO_Direction =     GPIO_PinInput;
202
        GPIO_InitStructure.GPIO_Direction =     GPIO_PinInput;
203
        GPIO_InitStructure.GPIO_Pin =                   GPIO_Pin_2;
203
        GPIO_InitStructure.GPIO_Pin =                   GPIO_Pin_2;
204
        GPIO_InitStructure.GPIO_Type =                  GPIO_Type_PushPull;
204
        GPIO_InitStructure.GPIO_Type =                  GPIO_Type_PushPull;
205
        GPIO_InitStructure.GPIO_IPInputConnected =      GPIO_IPInputConnected_Enable;
205
        GPIO_InitStructure.GPIO_IPInputConnected =      GPIO_IPInputConnected_Enable;
206
        GPIO_InitStructure.GPIO_Alternate =     GPIO_InputAlt1; // UART1_RxD
206
        GPIO_InitStructure.GPIO_Alternate =     GPIO_InputAlt1; // UART1_RxD
207
        GPIO_Init(GPIO3, &GPIO_InitStructure);
207
        GPIO_Init(GPIO3, &GPIO_InitStructure);
208
 
208
 
209
        /*Configure UART1_Tx pin GPIO3.3*/
209
        /*Configure UART1_Tx pin GPIO3.3*/
210
        GPIO_StructInit(&GPIO_InitStructure);
210
        GPIO_StructInit(&GPIO_InitStructure);
211
        GPIO_InitStructure.GPIO_Direction =     GPIO_PinOutput;
211
        GPIO_InitStructure.GPIO_Direction =     GPIO_PinOutput;
212
        GPIO_InitStructure.GPIO_Pin =                   GPIO_Pin_3;
212
        GPIO_InitStructure.GPIO_Pin =                   GPIO_Pin_3;
213
        GPIO_InitStructure.GPIO_Type =                  GPIO_Type_PushPull;
213
        GPIO_InitStructure.GPIO_Type =                  GPIO_Type_PushPull;
214
        GPIO_InitStructure.GPIO_Alternate =     GPIO_OutputAlt2; // UART1_TX
214
        GPIO_InitStructure.GPIO_Alternate =     GPIO_OutputAlt2; // UART1_TX
215
        GPIO_Init(GPIO3, &GPIO_InitStructure);
215
        GPIO_Init(GPIO3, &GPIO_InitStructure);
216
 
216
 
217
        /* UART1 configured as follow:
217
        /* UART1 configured as follow:
218
        - Word Length = 8 Bits
218
        - Word Length = 8 Bits
219
        - One Stop Bit
219
        - One Stop Bit
220
        - No parity
220
        - No parity
221
        - BaudRate = 57600 baud
221
        - BaudRate = 57600 baud
222
        - Hardware flow control Disabled
222
        - Hardware flow control Disabled
223
        - Receive and transmit enabled
223
        - Receive and transmit enabled
224
        - Receive and transmit FIFOs are Disabled
224
        - Receive and transmit FIFOs are Disabled
225
        */
225
        */
226
        UART_StructInit(&UART_InitStructure);
226
        UART_StructInit(&UART_InitStructure);
227
        UART_InitStructure.UART_WordLength =                    UART_WordLength_8D;
227
        UART_InitStructure.UART_WordLength =                    UART_WordLength_8D;
228
        UART_InitStructure.UART_StopBits =                              UART_StopBits_1;
228
        UART_InitStructure.UART_StopBits =                              UART_StopBits_1;
229
        UART_InitStructure.UART_Parity =                                UART_Parity_No ;
229
        UART_InitStructure.UART_Parity =                                UART_Parity_No ;
230
        UART_InitStructure.UART_BaudRate =                              UART1_BAUD_RATE;
230
        UART_InitStructure.UART_BaudRate =                              UART1_BAUD_RATE;
231
        UART_InitStructure. UART_HardwareFlowControl =  UART_HardwareFlowControl_None;
231
        UART_InitStructure. UART_HardwareFlowControl =  UART_HardwareFlowControl_None;
232
        UART_InitStructure.UART_Mode =                                  UART_Mode_Tx_Rx;
232
        UART_InitStructure.UART_Mode =                                  UART_Mode_Tx_Rx;
233
        UART_InitStructure.UART_FIFO =                                  UART_FIFO_Enable;
233
        UART_InitStructure.UART_FIFO =                                  UART_FIFO_Enable;
234
        UART_InitStructure.UART_TxFIFOLevel =                   UART_FIFOLevel_1_2;
234
        UART_InitStructure.UART_TxFIFOLevel =                   UART_FIFOLevel_1_2;
235
        UART_InitStructure.UART_RxFIFOLevel =                   UART_FIFOLevel_1_2;
235
        UART_InitStructure.UART_RxFIFOLevel =                   UART_FIFOLevel_1_2;
236
 
236
 
237
        UART_DeInit(UART1); // reset uart 1     to default
237
        UART_DeInit(UART1); // reset uart 1     to default
238
        UART_Init(UART1, &UART_InitStructure); // initialize uart 1
238
        UART_Init(UART1, &UART_InitStructure); // initialize uart 1
239
        // enable uart 1 interrupts selective
239
        // enable uart 1 interrupts selective
240
        UART_ITConfig(UART1, UART_IT_Receive | UART_IT_ReceiveTimeOut, ENABLE);
240
        UART_ITConfig(UART1, UART_IT_Receive | UART_IT_ReceiveTimeOut, ENABLE);
241
        UART_Cmd(UART1, ENABLE); // enable uart 1
241
        UART_Cmd(UART1, ENABLE); // enable uart 1
242
        // configure the uart 1 interupt line
242
        // configure the uart 1 interupt line
243
        VIC_Config(UART1_ITLine, VIC_IRQ, PRIORITY_UART1);
243
        VIC_Config(UART1_ITLine, VIC_IRQ, PRIORITY_UART1);
244
        // enable the uart 1 IRQ
244
        // enable the uart 1 IRQ
245
        VIC_ITCmd(UART1_ITLine, ENABLE);
245
        VIC_ITCmd(UART1_ITLine, ENABLE);
246
 
246
 
247
        // initialize the debug timer
247
        // initialize the debug timer
248
        UART1_DebugData_Timer = SetDelay(UART1_DebugData_Interval);
248
        UART1_DebugData_Timer = SetDelay(UART1_DebugData_Interval);
249
        UART1_NaviData_Timer = SetDelay(UART1_NaviData_Interval)+500;
249
        UART1_NaviData_Timer = SetDelay(UART1_NaviData_Interval)+500;
250
 
250
 
251
        // Fill Version Info Structure
251
        // Fill Version Info Structure
252
        UART_VersionInfo.SWMajor = VERSION_MAJOR;
252
        UART_VersionInfo.SWMajor = VERSION_MAJOR;
253
        UART_VersionInfo.SWMinor = VERSION_MINOR;
253
        UART_VersionInfo.SWMinor = VERSION_MINOR;
254
        UART_VersionInfo.SWPatch = VERSION_PATCH;
254
        UART_VersionInfo.SWPatch = VERSION_PATCH;
255
        UART_VersionInfo.ProtoMajor = VERSION_SERIAL_MAJOR;
255
        UART_VersionInfo.ProtoMajor = VERSION_SERIAL_MAJOR;
256
        UART_VersionInfo.ProtoMinor = VERSION_SERIAL_MINOR;
256
        UART_VersionInfo.ProtoMinor = VERSION_SERIAL_MINOR;
257
 
257
 
258
        NaviData.Version = NAVIDATA_VERSION;
258
        NaviData.Version = NAVIDATA_VERSION;
259
 
259
 
260
        UART1_PutString("\r\n UART1 init...ok");
260
        UART1_PutString("\r\n UART1 init...ok");
261
}
261
}
262
 
262
 
263
 
263
 
264
/****************************************************************/
264
/****************************************************************/
265
/*               USART1 receiver ISR                            */
265
/*               USART1 receiver ISR                            */
266
/****************************************************************/
266
/****************************************************************/
267
void UART1_IRQHandler(void)
267
void UART1_IRQHandler(void)
268
{
268
{
269
        static u8 abortState = 0;
269
        static u8 abortState = 0;
270
        u8 c;
270
        u8 c;
271
 
271
 
272
        IENABLE;
272
        IENABLE;
273
 
273
 
274
        if((UART_GetITStatus(UART1, UART_IT_Receive) != RESET) || (UART_GetITStatus(UART1, UART_IT_ReceiveTimeOut) != RESET) )
274
        if((UART_GetITStatus(UART1, UART_IT_Receive) != RESET) || (UART_GetITStatus(UART1, UART_IT_ReceiveTimeOut) != RESET) )
275
        {
275
        {
276
                // clear the pending bits!
276
                // clear the pending bits!
277
                UART_ClearITPendingBit(UART1, UART_IT_Receive);
277
                UART_ClearITPendingBit(UART1, UART_IT_Receive);
278
                UART_ClearITPendingBit(UART1, UART_IT_ReceiveTimeOut);
278
                UART_ClearITPendingBit(UART1, UART_IT_ReceiveTimeOut);
279
                // if debug UART is not UART1
279
                // if debug UART is not UART1
280
                if (DebugUART != UART1)
280
                if (DebugUART != UART1)
281
                {       // forward received data to the debug UART tx buffer
281
                {       // forward received data to the debug UART tx buffer
282
                        while(UART_GetFlagStatus(UART1, UART_FLAG_RxFIFOEmpty) != SET)
282
                        while(UART_GetFlagStatus(UART1, UART_FLAG_RxFIFOEmpty) != SET)
283
                        {
283
                        {
284
                                // move the byte from the rx buffer of UART1 to the tx buffer of DebugUART
284
                                // move the byte from the rx buffer of UART1 to the tx buffer of DebugUART
285
                                c = UART_ReceiveData(UART1);
285
                                c = UART_ReceiveData(UART1);
286
 
286
 
287
                                // check for abort condition (ESC ESC 0x55 0xAA 0x00)
287
                                // check for abort condition (ESC ESC 0x55 0xAA 0x00)
288
                                switch (abortState)
288
                                switch (abortState)
289
                                {
289
                                {
290
                                        case 0:
290
                                        case 0:
291
                                                if (c == 27) abortState++;
291
                                                if (c == 27) abortState++;
292
                                                break;
292
                                                break;
293
                                        case 1:
293
                                        case 1:
294
                                                if (c == 27) abortState++;
294
                                                if (c == 27) abortState++;
295
                                                else abortState = 0;
295
                                                else abortState = 0;
296
                                        break;
296
                                        break;
297
                                        case 2:
297
                                        case 2:
298
                                                if (c == 0x55) abortState++;
298
                                                if (c == 0x55) abortState++;
299
                                                else abortState = 0;
299
                                                else abortState = 0;
300
                                                break;
300
                                                break;
301
                                        case 3:
301
                                        case 3:
302
                                                if (c == 0xAA) abortState++;
302
                                                if (c == 0xAA) abortState++;
303
                                                else abortState = 0;
303
                                                else abortState = 0;
304
                                                break;
304
                                                break;
305
                                        case 4:
305
                                        case 4:
306
                                                if (c == 0x00)
306
                                                if (c == 0x00)
307
                                                {
307
                                                {
308
                                                        if(DebugUART == UART0)
308
                                                        if(DebugUART == UART0)
309
                                                        {
309
                                                        {
310
                                                                UART0_Connect_to_MKGPS(UART0_BAUD_RATE);
310
                                                                UART0_Connect_to_MKGPS(UART0_BAUD_RATE);
311
                                                                TIMER2_Init(); // enbable servo outputs
311
                                                                TIMER2_Init(); // enbable servo outputs
312
                                                                fifo_purge(&UART1_rx_fifo); // flush the whole fifo init buffer
312
                                                                fifo_purge(&UART1_rx_fifo); // flush the whole fifo init buffer
313
                                                        }
313
                                                        }
314
                                                        DebugUART = UART1;
314
                                                        DebugUART = UART1;
315
                                                }
315
                                                }
316
                                                abortState = 0;
316
                                                abortState = 0;
317
                                                break;
317
                                                break;
318
                                } // end switch abort state
318
                                } // end switch abort state
319
                                // if the Debug uart is not UART1, redirect input to the Debug UART
319
                                // if the Debug uart is not UART1, redirect input to the Debug UART
320
                                if (DebugUART != UART1)
320
                                if (DebugUART != UART1)
321
                                {
321
                                {
322
                                        // wait for space in the tx buffer of the DebugUART
322
                                        // wait for space in the tx buffer of the DebugUART
323
                                        while(UART_GetFlagStatus(DebugUART, UART_FLAG_TxFIFOFull) == SET) {};
323
                                        while(UART_GetFlagStatus(DebugUART, UART_FLAG_TxFIFOFull) == SET) {};
324
                                        // move byte to the tx fifo of the debug uart
324
                                        // move byte to the tx fifo of the debug uart
325
                                        UART_SendData(DebugUART, c);
325
                                        UART_SendData(DebugUART, c);
326
                                }
326
                                }
327
                        }
327
                        }
328
                }
328
                }
329
                else  // DebugUART == UART1 (normal operation)
329
                else  // DebugUART == UART1 (normal operation)
330
                {
330
                {
331
                        while(UART_GetFlagStatus(UART1, UART_FLAG_RxFIFOEmpty) != SET)
331
                        while(UART_GetFlagStatus(UART1, UART_FLAG_RxFIFOEmpty) != SET)
332
                        { // some byes in the hardware fifo
332
                        { // some byes in the hardware fifo
333
                            // get byte from hardware fifo
333
                            // get byte from hardware fifo
334
                        c = UART_ReceiveData(UART1);
334
                        c = UART_ReceiveData(UART1);
335
                                // put into the software fifo
335
                                // put into the software fifo
336
                                if(!fifo_put(&UART1_rx_fifo, c))
336
                                if(!fifo_put(&UART1_rx_fifo, c))
337
                                {       // fifo overflow
337
                                {       // fifo overflow
338
                                        //fifo_purge(&UART1_rx_fifo); // flush the whole buffer
338
                                        //fifo_purge(&UART1_rx_fifo); // flush the whole buffer
339
                                }
339
                                }
340
                        } // EOF while some byes in the hardware fifo
340
                        } // EOF while some byes in the hardware fifo
341
                } // eof DebugUart = UART1
341
                } // eof DebugUart = UART1
342
        }
342
        }
343
 
343
 
344
        IDISABLE;
344
        IDISABLE;
345
}
345
}
346
 
346
 
347
/**************************************************************/
347
/**************************************************************/
348
/* Process incomming data from debug uart                     */
348
/* Process incomming data from debug uart                     */
349
/**************************************************************/
349
/**************************************************************/
350
void UART1_ProcessRxData(void)
350
void UART1_ProcessRxData(void)
351
{
351
{
352
        // return on forwarding uart  or unlocked rx buffer
352
        // return on forwarding uart  or unlocked rx buffer
353
        if(DebugUART != UART1) return;
353
        if(DebugUART != UART1) return;
354
 
354
 
355
        u8 c;
355
        u8 c;
356
        // if rx buffer is not locked
356
        // if rx buffer is not locked
357
        if(UART1_rx_buffer.Locked == FALSE)
357
        if(UART1_rx_buffer.Locked == FALSE)
358
        {
358
        {
359
                //collect data from primary rx fifo
359
                //collect data from primary rx fifo
360
                while(fifo_get(&UART1_rx_fifo, &c))
360
                while(fifo_get(&UART1_rx_fifo, &c))
361
                {      
361
                {      
362
                        // break if complete frame is collected
362
                        // break if complete frame is collected
363
                        if(MKProtocol_CollectSerialFrame(&UART1_rx_buffer, c)) break;
363
                        if(MKProtocol_CollectSerialFrame(&UART1_rx_buffer, c)) break;
364
                }
364
                }
365
        }
365
        }
366
        if(UART1_rx_buffer.Locked == FALSE) return;
366
        if(UART1_rx_buffer.Locked == FALSE) return;
367
 
367
 
368
        Point_t * pPoint = NULL;
368
        Point_t * pPoint = NULL;
369
        SerialMsg_t SerialMsg;
369
        SerialMsg_t SerialMsg;
370
 
370
 
371
        // analyze header first
371
        // analyze header first
372
        MKProtocol_DecodeSerialFrameHeader(&UART1_rx_buffer, &SerialMsg);
372
        MKProtocol_DecodeSerialFrameHeader(&UART1_rx_buffer, &SerialMsg);
373
        if( SerialMsg.Address == FC_ADDRESS )
373
        if( SerialMsg.Address == FC_ADDRESS )
374
        {
374
        {
375
                switch(SerialMsg.CmdID)
375
                switch(SerialMsg.CmdID)
376
                {
376
                {
377
//                      case 'v': // version
377
//                      case 'v': // version
378
                        case 'y': // serial poti values
378
                        case 'y': // serial poti values
379
                        case 'b': // extern control
379
                        case 'b': // extern control
380
                                Buffer_Copy(&UART1_rx_buffer, &UART2_tx_buffer); //forward to FC
380
                                Buffer_Copy(&UART1_rx_buffer, &UART2_tx_buffer); //forward to FC
381
                                Buffer_Clear(&UART1_rx_buffer); // free rc buffer for next frame
381
                                Buffer_Clear(&UART1_rx_buffer); // free rc buffer for next frame
382
                                return; //end process rx data
382
                                return; //end process rx data
383
                        break;
383
                        break;
384
                }
384
                }
385
        }
385
        }
386
 
386
 
387
        MKProtocol_DecodeSerialFrameData(&UART1_rx_buffer, &SerialMsg); // decode serial frame in rxd buffer
387
        MKProtocol_DecodeSerialFrameData(&UART1_rx_buffer, &SerialMsg); // decode serial frame in rxd buffer
388
    if(SerialMsg.CmdID != 'z') SerialLinkOkay = 250;      // reset SerialTimeout, but not in case of the "ping"
388
    if(SerialMsg.CmdID != 'z') SerialLinkOkay = 250;      // reset SerialTimeout, but not in case of the "ping"
389
        switch(SerialMsg.Address) // check for Slave Address
389
        switch(SerialMsg.Address) // check for Slave Address
390
        {
390
        {
391
                case NC_ADDRESS:  // own Slave Address
391
                case NC_ADDRESS:  // own Slave Address
392
                switch(SerialMsg.CmdID)
392
                switch(SerialMsg.CmdID)
393
                {
393
                {
394
                        case 'z': // connection checker
394
                        case 'z': // connection checker
395
                                memcpy(&Echo, SerialMsg.pData, sizeof(Echo)); // copy echo pattern
395
                                memcpy(&Echo, SerialMsg.pData, sizeof(Echo)); // copy echo pattern
396
                                UART1_Request_Echo = TRUE;
396
                                UART1_Request_Echo = TRUE;
397
                                break;
397
                                break;
398
 
398
 
399
                        case 'e': // request for the text of the error status
399
                        case 'e': // request for the text of the error status
400
                                UART1_Request_ErrorMessage = TRUE;
400
                                UART1_Request_ErrorMessage = TRUE;
401
                                break;
401
                                break;
402
 
402
 
403
                        case 's'://  new target position
403
                        case 's'://  new target position
404
                                pPoint = (Point_t*)SerialMsg.pData;
404
                                pPoint = (Point_t*)SerialMsg.pData;
405
                                if(pPoint->Position.Status == NEWDATA)
405
                                if(pPoint->Position.Status == NEWDATA)
406
                                {
406
                                {
407
                                        if(pPoint->Type == POINT_TYPE_POI)
-
 
408
                                        {
-
 
409
                                                PointList_Clear(); // empty List
407
                                        //PointList_Clear(); // flush the list  
410
                                                pPoint->Index = 1; // must be one after empty list
408
                                        pPoint->Index = 1; // must be one after empty list
411
                                                POICount = 0;
-
 
412
                                                PointList_Append(pPoint);
-
 
413
                                                PointCount = 2;
-
 
414
                                                BeepTime = 50;
-
 
415
                                        }
-
 
416
                                        else
-
 
417
                                        if(pPoint->Type == POINT_TYPE_WP)
-
 
418
                                        {
-
 
419
                                                PointList_Clear(); // empty List
-
 
420
                                                PointCount = 1;
-
 
421
                                                pPoint->Index = 2; // No. 1 could be the POI
-
 
422
                                                WPCount = 0;
-
 
423
                                                PointList_Append(pPoint);
409
                                        PointList_SetAt(pPoint); // 
424
                                                PointCount = 2;
-
 
425
                                                BeepTime = 50;
-
 
426
                                                GPS_pWaypoint = PointList_WPBegin();
410
                                        GPS_pWaypoint = PointList_WPBegin(); // updates POI index
427
                                        }
-
 
428
                                        else
-
 
429
                                        if(pPoint->Type == POINT_TYPE_BOTH)
-
 
430
                                        {
-
 
431
                                                PointList_Clear(); // empty List
-
 
432
                                                pPoint->Index = 1;
-
 
433
                                                pPoint->Type = POINT_TYPE_POI;
-
 
434
                                                PointList_Append(pPoint);
-
 
435
                                                pPoint->Index = 2;
-
 
436
                                                pPoint->Type = POINT_TYPE_WP;
-
 
437
                                                PointList_Append(pPoint);
-
 
438
                                                BeepTime = 50;
411
                                        BeepTime = 50;
439
                                                GPS_pWaypoint = PointList_WPBegin();
-
 
440
                                        }
-
 
441
                                        else
-
 
442
                                        {
-
 
443
                                         PointList_Clear(); // empty List
-
 
444
                                         GPS_pWaypoint = PointList_WPBegin();
-
 
445
                                        }
-
 
446
                                }
412
                                }
447
                                break;
413
                                break;
448
 
414
 
449
                        case 'u': // redirect debug uart
415
                        case 'u': // redirect debug uart
450
                                switch(SerialMsg.pData[0])
416
                                switch(SerialMsg.pData[0])
451
                                {
417
                                {
452
                                        case UART_FLIGHTCTRL:
418
                                        case UART_FLIGHTCTRL:
453
                                                UART2_Init();                           // initialize UART2 to FC pins
419
                                                UART2_Init();                           // initialize UART2 to FC pins
454
                                                fifo_purge(&UART1_rx_fifo);
420
                                                fifo_purge(&UART1_rx_fifo);
455
                                                TIMER2_Deinit();                        // reduce irq load
421
                                                TIMER2_Deinit();                        // reduce irq load
456
                                                DebugUART = UART2;
422
                                                DebugUART = UART2;
457
                                                break;
423
                                                break;
458
                                        case UART_MK3MAG:
424
                                        case UART_MK3MAG:
459
                                                if(FC.StatusFlags & FC_STATUS_MOTOR_RUN) break; // not if the motors are running
425
                                                if(FC.StatusFlags & FC_STATUS_MOTOR_RUN) break; // not if the motors are running
460
                                                UART0_Connect_to_MK3MAG();      // mux UART0 to MK3MAG pins
426
                                                UART0_Connect_to_MK3MAG();      // mux UART0 to MK3MAG pins
461
                                                GPSData.Status = INVALID;
427
                                                GPSData.Status = INVALID;
462
                                                fifo_purge(&UART1_rx_fifo);
428
                                                fifo_purge(&UART1_rx_fifo);
463
                                                DebugUART = UART0;
429
                                                DebugUART = UART0;
464
                                                break;
430
                                                break;
465
                                        case UART_MKGPS:
431
                                        case UART_MKGPS:
466
                                                if(FC.StatusFlags & FC_STATUS_MOTOR_RUN) break; // not if the motors are running
432
                                                if(FC.StatusFlags & FC_STATUS_MOTOR_RUN) break; // not if the motors are running
467
                                                TIMER2_Deinit();                        // disable servo outputs to reduce irq load
433
                                                TIMER2_Deinit();                        // disable servo outputs to reduce irq load
468
                                                UART0_Connect_to_MKGPS(UART0_BAUD_RATE);        // connect UART0 to MKGPS pins
434
                                                UART0_Connect_to_MKGPS(UART0_BAUD_RATE);        // connect UART0 to MKGPS pins
469
                                                GPSData.Status = INVALID;
435
                                                GPSData.Status = INVALID;
470
                                                fifo_purge(&UART1_rx_fifo);
436
                                                fifo_purge(&UART1_rx_fifo);
471
                                                DebugUART = UART0;
437
                                                DebugUART = UART0;
472
                                                break;
438
                                                break;
473
                                        default:
439
                                        default:
474
                                                break;
440
                                                break;
475
                                }
441
                                }
476
                                break;
442
                                break;
477
 
443
 
478
                        case 'w'://  Append Point to List
444
                        case 'w'://  Set point in list at index
479
                                {
445
                                {
480
                                        pPoint = (Point_t*)SerialMsg.pData;
446
                                        pPoint = (Point_t*)SerialMsg.pData;
481
 
447
 
482
                                        if((pPoint->Position.Status == INVALID) && (pPoint->Index == 0))
448
                                        if((pPoint->Position.Status == INVALID) && (pPoint->Index == 0))
483
                                        {
449
                                        {
484
                                                PointList_Clear();
450
                                                PointList_Clear();
485
                                                GPS_pWaypoint = PointList_WPBegin();
451
                                                GPS_pWaypoint = PointList_WPBegin();
486
                                                UART1_Request_NewPoint = TRUE; // return new point count        
452
                                                UART1_Request_WritePoint = 0; // return new point count 
487
                                        }
453
                                        }
488
                                        else
454
                                        else
489
                                        {  // app current WP to the list
455
                                        {  // update WP in list at index
-
 
456
                                                UART1_Request_WritePoint = PointList_SetAt(pPoint);
490
                                                if(PointList_Append(pPoint))
457
                                                if(UART1_Request_WritePoint == pPoint->Index)
491
                                                {
458
                                                {
492
                                                        BeepTime = 500;
459
                                                        BeepTime = 500;
493
                                                        UART1_Request_NewPoint = TRUE; // return new WP number
-
 
494
                                                }
460
                                                }
495
                                        }
461
                                        }
496
                                }
462
                                }
497
                                break;
463
                                break;
498
 
464
 
499
                        case 'x'://  Read Waypoint from List
465
                        case 'x'://  Read Waypoint from List
500
                                UART1_Request_ReadPoint = SerialMsg.pData[0];
466
                                UART1_Request_ReadPoint = SerialMsg.pData[0];
501
                                break;
467
                                break;
502
 
468
 
503
                        case 'j':// Set/Get NC-Parameter
469
                        case 'j':// Set/Get NC-Parameter
504
                                switch(SerialMsg.pData[0])
470
                                switch(SerialMsg.pData[0])
505
                                {
471
                                {
506
                                        case 0: // get
472
                                        case 0: // get
507
                                        break;
473
                                        break;
508
 
474
 
509
                                        case 1: // set
475
                                        case 1: // set
510
                                        {
476
                                        {
511
                                                s16 value;
477
                                                s16 value;
512
                                                value = SerialMsg.pData[2] + (s16)SerialMsg.pData[3] * 0x0100;
478
                                                value = SerialMsg.pData[2] + (s16)SerialMsg.pData[3] * 0x0100;
513
                                                NCParams_SetValue(SerialMsg.pData[1], &value);
479
                                                NCParams_SetValue(SerialMsg.pData[1], &value);
514
                                        }
480
                                        }
515
                                        break;
481
                                        break;
516
 
482
 
517
                                        default:
483
                                        default:
518
                                        break;
484
                                        break;
519
                                }
485
                                }
520
                                UART1_Request_ParameterId = SerialMsg.pData[1];
486
                                UART1_Request_ParameterId = SerialMsg.pData[1];
521
                                UART1_Request_Parameter = TRUE;
487
                                UART1_Request_Parameter = TRUE;
522
                                break;
488
                                break;
523
                        default:
489
                        default:
524
                                // unsupported command recieved
490
                                // unsupported command recieved
525
                                break;
491
                                break;
526
                } // case NC_ADDRESS
492
                } // case NC_ADDRESS
527
                // "break;" is missing here to fall thru to the common commands
493
                // "break;" is missing here to fall thru to the common commands
528
 
494
 
529
                default:  // and any other Slave Address
495
                default:  // and any other Slave Address
530
 
496
 
531
                switch(SerialMsg.CmdID) // check CmdID
497
                switch(SerialMsg.CmdID) // check CmdID
532
                {
498
                {
533
                        case 'a':// request for the labels of the analog debug outputs
499
                        case 'a':// request for the labels of the analog debug outputs
534
                                UART1_Request_DebugLabel = SerialMsg.pData[0];
500
                                UART1_Request_DebugLabel = SerialMsg.pData[0];
535
                                if(UART1_Request_DebugLabel > 31) UART1_Request_DebugLabel = 31;
501
                                if(UART1_Request_DebugLabel > 31) UART1_Request_DebugLabel = 31;
536
                                break;
502
                                break;
537
                        /*
503
                        /*
538
                        case 'b': // submit extern control
504
                        case 'b': // submit extern control
539
                                memcpy(&ExternControl, SerialMsg.pData, sizeof(ExternControl));
505
                                memcpy(&ExternControl, SerialMsg.pData, sizeof(ExternControl));
540
                                UART1_ConfirmFrame = ExternControl.Frame;
506
                                UART1_ConfirmFrame = ExternControl.Frame;
541
                                break;
507
                                break;
542
                        */
508
                        */
543
                        case 'd': // request for debug data;
509
                        case 'd': // request for debug data;
544
                                UART1_DebugData_Interval = (u32) SerialMsg.pData[0] * 10;
510
                                UART1_DebugData_Interval = (u32) SerialMsg.pData[0] * 10;
545
                                if(UART1_DebugData_Interval > 0) UART1_Request_DebugData = TRUE;
511
                                if(UART1_DebugData_Interval > 0) UART1_Request_DebugData = TRUE;
546
                                UART1_AboTimeOut = SetDelay(ABO_TIMEOUT);
512
                                UART1_AboTimeOut = SetDelay(ABO_TIMEOUT);
547
                                break;
513
                                break;
548
 
514
 
549
                        case 'c': // request for 3D data;
515
                        case 'c': // request for 3D data;
550
                                UART1_Data3D_Interval = (u32) SerialMsg.pData[0] * 10;
516
                                UART1_Data3D_Interval = (u32) SerialMsg.pData[0] * 10;
551
                                if(UART1_Data3D_Interval > 0) UART1_Request_Data3D = TRUE;
517
                                if(UART1_Data3D_Interval > 0) UART1_Request_Data3D = TRUE;
552
                                UART1_AboTimeOut = SetDelay(ABO_TIMEOUT);
518
                                UART1_AboTimeOut = SetDelay(ABO_TIMEOUT);
553
                                break;
519
                                break;
554
 
520
 
555
                        case 'h':// reqest for display line
521
                        case 'h':// reqest for display line
556
                                if((SerialMsg.pData[0]& 0x80) == 0x00)// old format
522
                                if((SerialMsg.pData[0]& 0x80) == 0x00)// old format
557
                                {
523
                                {
558
                                        UART1_DisplayLine = 2;
524
                                        UART1_DisplayLine = 2;
559
                                        UART1_Display_Interval = 0;
525
                                        UART1_Display_Interval = 0;
560
                                }
526
                                }
561
                                else
527
                                else
562
                                {
528
                                {
563
                                        UART1_DisplayKeys |= ~SerialMsg.pData[0];
529
                                        UART1_DisplayKeys |= ~SerialMsg.pData[0];
564
                                        UART1_Display_Interval = (u32) SerialMsg.pData[1] * 10;
530
                                        UART1_Display_Interval = (u32) SerialMsg.pData[1] * 10;
565
                                        UART1_DisplayLine = 4;
531
                                        UART1_DisplayLine = 4;
566
                                        UART1_AboTimeOut = SetDelay(ABO_TIMEOUT);
532
                                        UART1_AboTimeOut = SetDelay(ABO_TIMEOUT);
567
                                }
533
                                }
568
                                UART1_Request_Display = TRUE;
534
                                UART1_Request_Display = TRUE;
569
                                break;
535
                                break;
570
 
536
 
571
                        case 'l':// reqest for display columns
537
                        case 'l':// reqest for display columns
572
                                MenuItem = SerialMsg.pData[0];
538
                                MenuItem = SerialMsg.pData[0];
573
                                UART1_Request_Display1 = TRUE;
539
                                UART1_Request_Display1 = TRUE;
574
                                break;
540
                                break;
575
 
541
 
576
                        case 'o': // request for navigation information
542
                        case 'o': // request for navigation information
577
                                UART1_NaviData_Interval = (u32) SerialMsg.pData[0] * 10;
543
                                UART1_NaviData_Interval = (u32) SerialMsg.pData[0] * 10;
578
                                if(UART1_NaviData_Interval > 0) UART1_Request_NaviData = TRUE;
544
                                if(UART1_NaviData_Interval > 0) UART1_Request_NaviData = TRUE;
579
                                UART1_AboTimeOut = SetDelay(ABO_TIMEOUT);
545
                                UART1_AboTimeOut = SetDelay(ABO_TIMEOUT);
580
                                break;
546
                                break;
581
 
547
 
582
                        case 'v': // request for version info
548
                        case 'v': // request for version info
583
                                UART1_Request_VersionInfo = TRUE;
549
                                UART1_Request_VersionInfo = TRUE;
584
                                break;
550
                                break;
585
                        default:
551
                        default:
586
                                // unsupported command recieved
552
                                // unsupported command recieved
587
                                break;
553
                                break;
588
                }
554
                }
589
                break; // default:
555
                break; // default:
590
        }
556
        }
591
        Buffer_Clear(&UART1_rx_buffer); // free rc buffer for next frame
557
        Buffer_Clear(&UART1_rx_buffer); // free rc buffer for next frame
592
}
558
}
593
 
559
 
594
 
560
 
595
/*****************************************************/
561
/*****************************************************/
596
/*                   Send a character                */
562
/*                   Send a character                */
597
/*****************************************************/
563
/*****************************************************/
598
s16 UART1_Putchar(char c)
564
s16 UART1_Putchar(char c)
599
{
565
{
600
        if (c == '\n') UART1_Putchar('\r');
566
        if (c == '\n') UART1_Putchar('\r');
601
        // wait until txd fifo is not full
567
        // wait until txd fifo is not full
602
        while (UART_GetFlagStatus(UART1, UART_FLAG_TxFIFOFull) != RESET);
568
        while (UART_GetFlagStatus(UART1, UART_FLAG_TxFIFOFull) != RESET);
603
        // transmit byte
569
        // transmit byte
604
        UART_SendData(UART1, c);
570
        UART_SendData(UART1, c);
605
        return (0);
571
        return (0);
606
}
572
}
607
 
573
 
608
/*****************************************************/
574
/*****************************************************/
609
/*       Send a string to the debug uart              */
575
/*       Send a string to the debug uart              */
610
/*****************************************************/
576
/*****************************************************/
611
void UART1_PutString(u8 *s)
577
void UART1_PutString(u8 *s)
612
{
578
{
613
        if(s == NULL) return;
579
        if(s == NULL) return;
614
        while (*s != '\0' && DebugUART == UART1)
580
        while (*s != '\0' && DebugUART == UART1)
615
        {
581
        {
616
                UART1_Putchar(*s);
582
                UART1_Putchar(*s);
617
                s ++;
583
                s ++;
618
        }
584
        }
619
}
585
}
620
 
586
 
621
 
587
 
622
/**************************************************************/
588
/**************************************************************/
623
/*         Transmit tx buffer via debug uart                  */
589
/*         Transmit tx buffer via debug uart                  */
624
/**************************************************************/
590
/**************************************************************/
625
void UART1_Transmit(void)
591
void UART1_Transmit(void)
626
{
592
{
627
        u8 tmp_tx;
593
        u8 tmp_tx;
628
        if(DebugUART != UART1) return;
594
        if(DebugUART != UART1) return;
629
        // if something has to be send and the txd fifo is not full
595
        // if something has to be send and the txd fifo is not full
630
        if(UART1_tx_buffer.Locked == TRUE)
596
        if(UART1_tx_buffer.Locked == TRUE)
631
        {
597
        {
632
                // while there is some space in the tx fifo
598
                // while there is some space in the tx fifo
633
                while(UART_GetFlagStatus(UART1, UART_FLAG_TxFIFOFull) != SET)
599
                while(UART_GetFlagStatus(UART1, UART_FLAG_TxFIFOFull) != SET)
634
                {
600
                {
635
                        tmp_tx = UART1_tx_buffer.pData[UART1_tx_buffer.Position++]; // read next byte from txd buffer
601
                        tmp_tx = UART1_tx_buffer.pData[UART1_tx_buffer.Position++]; // read next byte from txd buffer
636
                        UART_SendData(UART1, tmp_tx); // put character to txd fifo
602
                        UART_SendData(UART1, tmp_tx); // put character to txd fifo
637
                        // if terminating character or end of txd buffer reached
603
                        // if terminating character or end of txd buffer reached
638
                        if((tmp_tx == '\r') || (UART1_tx_buffer.Position == UART1_tx_buffer.DataBytes))
604
                        if((tmp_tx == '\r') || (UART1_tx_buffer.Position == UART1_tx_buffer.DataBytes))
639
                        {
605
                        {
640
                                Buffer_Clear(&UART1_tx_buffer); // clear txd buffer
606
                                Buffer_Clear(&UART1_tx_buffer); // clear txd buffer
641
                                break; // end while loop
607
                                break; // end while loop
642
                        }
608
                        }
643
                }
609
                }
644
        }
610
        }
645
}
611
}
646
 
612
 
647
/**************************************************************/
613
/**************************************************************/
648
/* Send the answers to incomming commands at the debug uart   */
614
/* Send the answers to incomming commands at the debug uart   */
649
/**************************************************************/
615
/**************************************************************/
650
void UART1_TransmitTxData(void)
616
void UART1_TransmitTxData(void)
651
{
617
{
652
        if(DebugUART != UART1) return;
618
        if(DebugUART != UART1) return;
653
 
619
 
654
        if(CheckDelay(UART1_AboTimeOut))
620
        if(CheckDelay(UART1_AboTimeOut))
655
        {
621
        {
656
                UART1_DebugData_Interval = 0;
622
                UART1_DebugData_Interval = 0;
657
                UART1_NaviData_Interval = 0;
623
                UART1_NaviData_Interval = 0;
658
                UART1_Data3D_Interval = 0;
624
                UART1_Data3D_Interval = 0;
659
                UART1_Display_Interval = 0;
625
                UART1_Display_Interval = 0;
660
        }
626
        }
661
 
627
 
662
        UART1_Transmit(); // output pending bytes in tx buffer
628
        UART1_Transmit(); // output pending bytes in tx buffer
663
        if((UART1_tx_buffer.Locked == TRUE)) return;
629
        if((UART1_tx_buffer.Locked == TRUE)) return;
664
 
630
 
665
        if(UART1_Request_Parameter && (UART1_tx_buffer.Locked == FALSE))
631
        if(UART1_Request_Parameter && (UART1_tx_buffer.Locked == FALSE))
666
        {
632
        {
667
                s16 ParamValue;
633
                s16 ParamValue;
668
                NCParams_GetValue(UART1_Request_ParameterId, &ParamValue);
634
                NCParams_GetValue(UART1_Request_ParameterId, &ParamValue);
669
                //sprintf(text, "\r\nId=%d, value = %d\r\n", UART1_Request_ParameterId, ParamValue);
635
                //sprintf(text, "\r\nId=%d, value = %d\r\n", UART1_Request_ParameterId, ParamValue);
670
                //UART1_PutString(text);
636
                //UART1_PutString(text);
671
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'J', NC_ADDRESS, 2, &UART1_Request_ParameterId, sizeof(UART1_Request_ParameterId), &ParamValue, sizeof(ParamValue)); // answer the param request
637
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'J', NC_ADDRESS, 2, &UART1_Request_ParameterId, sizeof(UART1_Request_ParameterId), &ParamValue, sizeof(ParamValue)); // answer the param request
672
                UART1_Request_Parameter = FALSE;
638
                UART1_Request_Parameter = FALSE;
673
        }
639
        }
674
        else if(UART1_Request_Echo && (UART1_tx_buffer.Locked == FALSE))
640
        else if(UART1_Request_Echo && (UART1_tx_buffer.Locked == FALSE))
675
        {
641
        {
676
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'Z', NC_ADDRESS, 1, &Echo, sizeof(Echo)); // answer the echo request
642
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'Z', NC_ADDRESS, 1, &Echo, sizeof(Echo)); // answer the echo request
677
                Echo = 0; // reset echo value
643
                Echo = 0; // reset echo value
678
                UART1_Request_Echo = FALSE;
644
                UART1_Request_Echo = FALSE;
679
        }
645
        }
680
        else if(UART1_Request_NewPoint && (UART1_tx_buffer.Locked == FALSE))
646
        else if((UART1_Request_WritePoint!= 0xFF) && (UART1_tx_buffer.Locked == FALSE))
681
        {
647
        {
682
                u8 PointCount = PointList_GetCount();
-
 
683
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'W', NC_ADDRESS, 1, &PointCount, sizeof(PointCount));
648
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'W', NC_ADDRESS, 1, &UART1_Request_WritePoint, sizeof(UART1_Request_WritePoint));
684
                UART1_Request_NewPoint = FALSE;
649
                UART1_Request_WritePoint = 0xFF;
685
        }
650
        }
686
        else if((UART1_Request_ReadPoint) && (UART1_tx_buffer.Locked == FALSE))
651
        else if((UART1_Request_ReadPoint) && (UART1_tx_buffer.Locked == FALSE))
687
        {
652
        {
688
                u8 PointCount = PointList_GetCount();
653
                u8 PointCount = PointList_GetCount();
689
                if (UART1_Request_ReadPoint <= PointCount)
654
                if (UART1_Request_ReadPoint <= PointCount)
690
                {
655
                {
691
                        MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'X', NC_ADDRESS, 3, &PointCount, 1, &UART1_Request_ReadPoint, 1, PointList_GetAt(UART1_Request_ReadPoint), sizeof(Point_t));
656
                        MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'X', NC_ADDRESS, 3, &PointCount, 1, &UART1_Request_ReadPoint, 1, PointList_GetAt(UART1_Request_ReadPoint), sizeof(Point_t));
692
                }
657
                }
693
                else
658
                else
694
                {
659
                {
695
                        MKProtocol_CreateSerialFrame(&UART1_tx_buffer,'X', NC_ADDRESS, 1, &PointCount, sizeof(PointCount));
660
                        MKProtocol_CreateSerialFrame(&UART1_tx_buffer,'X', NC_ADDRESS, 1, &PointCount, sizeof(PointCount));
696
                }
661
                }
697
                UART1_Request_ReadPoint = 0;
662
                UART1_Request_ReadPoint = 0;
698
        }
663
        }
699
        else if((UART1_Request_DebugLabel != 0xFF) && (UART1_tx_buffer.Locked == FALSE))
664
        else if((UART1_Request_DebugLabel != 0xFF) && (UART1_tx_buffer.Locked == FALSE))
700
        {
665
        {
701
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'A', NC_ADDRESS, 2, &UART1_Request_DebugLabel, sizeof(UART1_Request_DebugLabel), (u8 *) ANALOG_LABEL[UART1_Request_DebugLabel], 16);
666
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'A', NC_ADDRESS, 2, &UART1_Request_DebugLabel, sizeof(UART1_Request_DebugLabel), (u8 *) ANALOG_LABEL[UART1_Request_DebugLabel], 16);
702
                UART1_Request_DebugLabel = 0xFF;
667
                UART1_Request_DebugLabel = 0xFF;
703
        }
668
        }
704
        else if(( ((UART1_NaviData_Interval > 0) && CheckDelay(UART1_NaviData_Timer) ) || UART1_Request_NaviData) && (UART1_tx_buffer.Locked == FALSE))
669
        else if(( ((UART1_NaviData_Interval > 0) && CheckDelay(UART1_NaviData_Timer) ) || UART1_Request_NaviData) && (UART1_tx_buffer.Locked == FALSE))
705
        {
670
        {
706
                NaviData.Errorcode = ErrorCode;
671
                NaviData.Errorcode = ErrorCode;
707
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'O', NC_ADDRESS,1, (u8 *)&NaviData, sizeof(NaviData));
672
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'O', NC_ADDRESS,1, (u8 *)&NaviData, sizeof(NaviData));
708
                UART1_NaviData_Timer = SetDelay(UART1_NaviData_Interval);
673
                UART1_NaviData_Timer = SetDelay(UART1_NaviData_Interval);
709
                UART1_Request_NaviData = FALSE;
674
                UART1_Request_NaviData = FALSE;
710
        }
675
        }
711
        else if( (( (UART1_DebugData_Interval > 0) && CheckDelay(UART1_DebugData_Timer)) || UART1_Request_DebugData) && (UART1_tx_buffer.Locked == FALSE))
676
        else if( (( (UART1_DebugData_Interval > 0) && CheckDelay(UART1_DebugData_Timer)) || UART1_Request_DebugData) && (UART1_tx_buffer.Locked == FALSE))
712
        {
677
        {
713
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'D', NC_ADDRESS, 1,(u8 *)&DebugOut, sizeof(DebugOut));
678
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'D', NC_ADDRESS, 1,(u8 *)&DebugOut, sizeof(DebugOut));
714
                UART1_DebugData_Timer = SetDelay(UART1_DebugData_Interval);
679
                UART1_DebugData_Timer = SetDelay(UART1_DebugData_Interval);
715
                UART1_Request_DebugData = FALSE;
680
                UART1_Request_DebugData = FALSE;
716
        }
681
        }
717
        else if((( (UART1_Data3D_Interval > 0) && CheckDelay(UART1_Data3D_Timer) ) || UART1_Request_Data3D) && (UART1_tx_buffer.Locked == FALSE))
682
        else if((( (UART1_Data3D_Interval > 0) && CheckDelay(UART1_Data3D_Timer) ) || UART1_Request_Data3D) && (UART1_tx_buffer.Locked == FALSE))
718
        {
683
        {
719
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'C', NC_ADDRESS, 1,(u8 *)&Data3D, sizeof(Data3D));
684
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'C', NC_ADDRESS, 1,(u8 *)&Data3D, sizeof(Data3D));
720
                UART1_Data3D_Timer = SetDelay(UART1_Data3D_Interval);
685
                UART1_Data3D_Timer = SetDelay(UART1_Data3D_Interval);
721
                UART1_Request_Data3D = FALSE;
686
                UART1_Request_Data3D = FALSE;
722
        }
687
        }
723
        /*
688
        /*
724
        else if(UART1_ConfirmFrame && (UART1_tx_buffer.Locked == FALSE))
689
        else if(UART1_ConfirmFrame && (UART1_tx_buffer.Locked == FALSE))
725
        {
690
        {
726
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'B', NC_ADDRESS, 1, &UART1_ConfirmFrame, sizeof(UART1_ConfirmFrame));
691
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'B', NC_ADDRESS, 1, &UART1_ConfirmFrame, sizeof(UART1_ConfirmFrame));
727
                UART1_ConfirmFrame = 0;
692
                UART1_ConfirmFrame = 0;
728
        }
693
        }
729
        */
694
        */
730
        /*
695
        /*
731
        else if(UART1_Request_ExternalControl && (UART1_tx_buffer.Locked == FALSE))
696
        else if(UART1_Request_ExternalControl && (UART1_tx_buffer.Locked == FALSE))
732
        {
697
        {
733
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'G', NC_ADDRESS, 1, (u8 *)&ExternControl, sizeof(ExternControl));
698
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'G', NC_ADDRESS, 1, (u8 *)&ExternControl, sizeof(ExternControl));
734
                UART1_Request_ExternalControl = FALSE;
699
                UART1_Request_ExternalControl = FALSE;
735
        }
700
        }
736
        */
701
        */
737
        else if( (( (UART1_Display_Interval > 0) && CheckDelay(UART1_Display_Timer)) || UART1_Request_Display) && (UART1_tx_buffer.Locked == FALSE))
702
        else if( (( (UART1_Display_Interval > 0) && CheckDelay(UART1_Display_Timer)) || UART1_Request_Display) && (UART1_tx_buffer.Locked == FALSE))
738
        {
703
        {
739
                if(UART1_DisplayLine > 3)
704
                if(UART1_DisplayLine > 3)
740
                {
705
                {
741
                        Menu_Update(UART1_DisplayKeys);
706
                        Menu_Update(UART1_DisplayKeys);
742
                        UART1_DisplayKeys = 0;
707
                        UART1_DisplayKeys = 0;
743
                        MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'H', NC_ADDRESS, 1, (u8*)DisplayBuff, sizeof(DisplayBuff));
708
                        MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'H', NC_ADDRESS, 1, (u8*)DisplayBuff, sizeof(DisplayBuff));
744
                }
709
                }
745
                else
710
                else
746
                {
711
                {
747
                        UART1_DisplayLine = 2;
712
                        UART1_DisplayLine = 2;
748
                        sprintf(text,"!!! incompatible !!!");
713
                        sprintf(text,"!!! incompatible !!!");
749
                        MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'H', NC_ADDRESS, 2, &UART1_DisplayLine, sizeof(UART1_DisplayLine), (u8*)&text, 20);
714
                        MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'H', NC_ADDRESS, 2, &UART1_DisplayLine, sizeof(UART1_DisplayLine), (u8*)&text, 20);
750
                        if(UART1_DisplayLine++ > 3) UART1_DisplayLine = 0;
715
                        if(UART1_DisplayLine++ > 3) UART1_DisplayLine = 0;
751
                }
716
                }
752
                UART1_Display_Timer = SetDelay(UART1_Display_Interval);
717
                UART1_Display_Timer = SetDelay(UART1_Display_Interval);
753
                UART1_Request_Display = FALSE;
718
                UART1_Request_Display = FALSE;
754
        }
719
        }
755
        else if(UART1_Request_Display1 && (UART1_tx_buffer.Locked == FALSE))
720
        else if(UART1_Request_Display1 && (UART1_tx_buffer.Locked == FALSE))
756
        {
721
        {
757
                Menu_Update(0);
722
                Menu_Update(0);
758
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'L', NC_ADDRESS, 3, (u8*)&MenuItem, sizeof(MenuItem), (u8*)&MaxMenuItem, sizeof(MaxMenuItem),(u8*)DisplayBuff, sizeof(DisplayBuff));
723
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'L', NC_ADDRESS, 3, (u8*)&MenuItem, sizeof(MenuItem), (u8*)&MaxMenuItem, sizeof(MaxMenuItem),(u8*)DisplayBuff, sizeof(DisplayBuff));
759
                UART1_Request_Display1 = FALSE;
724
                UART1_Request_Display1 = FALSE;
760
        }
725
        }
761
        else if(UART1_Request_VersionInfo && (UART1_tx_buffer.Locked == FALSE))
726
        else if(UART1_Request_VersionInfo && (UART1_tx_buffer.Locked == FALSE))
762
        {
727
        {
763
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'V', NC_ADDRESS,1, (u8 *)&UART_VersionInfo, sizeof(UART_VersionInfo));
728
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'V', NC_ADDRESS,1, (u8 *)&UART_VersionInfo, sizeof(UART_VersionInfo));
764
                UART1_Request_VersionInfo = FALSE;
729
                UART1_Request_VersionInfo = FALSE;
765
        }
730
        }
766
        else if(UART1_Request_ErrorMessage && (UART1_tx_buffer.Locked == FALSE))
731
        else if(UART1_Request_ErrorMessage && (UART1_tx_buffer.Locked == FALSE))
767
        {
732
        {
768
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'E', NC_ADDRESS, 1, (u8 *)&ErrorMSG, sizeof(ErrorMSG));
733
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer, 'E', NC_ADDRESS, 1, (u8 *)&ErrorMSG, sizeof(ErrorMSG));
769
                UART1_Request_ErrorMessage = FALSE;
734
                UART1_Request_ErrorMessage = FALSE;
770
        }
735
        }
771
#ifdef DEBUG                                                                                                                    // only include functions if DEBUG is defined
736
#ifdef DEBUG                                                                                                                    // only include functions if DEBUG is defined
772
        if(SendDebugOutput && (UART1_tx_buffer.Locked == FALSE))
737
        if(SendDebugOutput && (UART1_tx_buffer.Locked == FALSE))
773
        {
738
        {
774
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer,'0', NC_ADDRESS, 1, (u8 *) &tDebug, sizeof(tDebug));
739
                MKProtocol_CreateSerialFrame(&UART1_tx_buffer,'0', NC_ADDRESS, 1, (u8 *) &tDebug, sizeof(tDebug));
775
                SendDebugOutput = 0;
740
                SendDebugOutput = 0;
776
        }
741
        }
777
#endif  
742
#endif  
778
        UART1_Transmit(); // output pending bytes in tx buffer
743
        UART1_Transmit(); // output pending bytes in tx buffer
779
}
744
}
780
 
745
 
781
 
746