Subversion Repositories FlightCtrl

Rev

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

Rev Author Line No. Line
1180 killagreg 1
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
2
// + Copyright (c) 04.2007 Holger Buss
3
// + Nur für den privaten Gebrauch
4
// + www.MikroKopter.com
5
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
6
// + Es gilt für das gesamte Projekt (Hardware, Software, Binärfiles, Sourcecode und Dokumentation),
7
// + dass eine Nutzung (auch auszugsweise) nur für den privaten (nicht-kommerziellen) Gebrauch zulässig ist.
8
// + Sollten direkte oder indirekte kommerzielle Absichten verfolgt werden, ist mit uns (info@mikrokopter.de) Kontakt
9
// + bzgl. der Nutzungsbedingungen aufzunehmen.
10
// + Eine kommerzielle Nutzung ist z.B.Verkauf von MikroKoptern, Bestückung und Verkauf von Platinen oder Bausätzen,
11
// + Verkauf von Luftbildaufnahmen, usw.
12
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
13
// + Werden Teile des Quellcodes (mit oder ohne Modifikation) weiterverwendet oder veröffentlicht,
14
// + unterliegen sie auch diesen Nutzungsbedingungen und diese Nutzungsbedingungen incl. Copyright müssen dann beiliegen
15
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
16
// + Sollte die Software (auch auszugesweise) oder sonstige Informationen des MikroKopter-Projekts
17
// + auf anderen Webseiten oder sonstigen Medien veröffentlicht werden, muss unsere Webseite "http://www.mikrokopter.de"
18
// + eindeutig als Ursprung verlinkt werden
19
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
20
// + Keine Gewähr auf Fehlerfreiheit, Vollständigkeit oder Funktion
21
// + Benutzung auf eigene Gefahr
22
// + Wir übernehmen keinerlei Haftung für direkte oder indirekte Personen- oder Sachschäden
23
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
24
// + Die Portierung der Software (oder Teile davon) auf andere Systeme (ausser der Hardware von www.mikrokopter.de) ist nur
25
// + mit unserer Zustimmung zulässig
26
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
27
// + Die Funktion printf_P() unterliegt ihrer eigenen Lizenz und ist hiervon nicht betroffen
28
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
29
// + Redistributions of source code (with or without modifications) must retain the above copyright notice,
30
// + this list of conditions and the following disclaimer.
31
// +   * Neither the name of the copyright holders nor the names of contributors may be used to endorse or promote products derived
32
// +     from this software without specific prior written permission.
33
// +   * The use of this project (hardware, software, binary files, sources and documentation) is only permittet
34
// +     for non-commercial use (directly or indirectly)
35
// +     Commercial use (for excample: selling of MikroKopters, selling of PCBs, assembly, ...) is only permitted
36
// +     with our written permission
37
// +   * If sources or documentations are redistributet on other webpages, out webpage (http://www.MikroKopter.de) must be
38
// +     clearly linked as origin
39
// +   * porting to systems other than hardware from www.mikrokopter.de is not allowed
40
// +  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
41
// +  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
42
// +  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
43
// +  ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
44
// +  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
45
// +  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
46
// +  SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
47
// +  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN// +  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
48
// +  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
49
// +  POSSIBILITY OF SUCH DAMAGE.
50
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
886 killagreg 51
#include <avr/io.h>
52
#include <avr/interrupt.h>
53
#include <string.h>
54
#include <stdlib.h>
1180 killagreg 55
#include "main.h"
886 killagreg 56
#include "spi.h"
57
#include "fc.h"
58
#include "rc.h"
59
#include "eeprom.h"
1180 killagreg 60
#include "uart0.h"
886 killagreg 61
#include "timer0.h"
936 killagreg 62
#include "analog.h"
304 ingob 63
 
886 killagreg 64
#define SPI_TXSYNCBYTE1 0xAA
65
#define SPI_TXSYNCBYTE2 0x83
66
#define SPI_RXSYNCBYTE1 0x81
67
#define SPI_RXSYNCBYTE2 0x55
304 ingob 68
 
886 killagreg 69
typedef enum
70
{
71
        SPI_SYNC1,
72
        SPI_SYNC2,
73
        SPI_DATA
74
} SPI_RXState_t;
708 ingob 75
 
606 ingob 76
 
886 killagreg 77
// data exchange packets to and From NaviCtrl
1078 killagreg 78
ToNaviCtrl_t                    ToNaviCtrl;
79
FromNaviCtrl_t                  FromNaviCtrl;
708 ingob 80
 
1078 killagreg 81
SPI_VersionInfo_t SPI_VersionInfo;
82
 
886 killagreg 83
// rx packet buffer
84
#define SPI_RXBUFFER_LEN sizeof(FromNaviCtrl)
85
uint8_t SPI_RxBuffer[SPI_RXBUFFER_LEN];
86
uint8_t SPI_RxBufferIndex = 0;
87
uint8_t SPI_RxBuffer_Request = 0;
720 ingob 88
 
886 killagreg 89
// tx packet buffer
90
#define SPI_TXBUFFER_LEN sizeof(ToNaviCtrl)
91
uint8_t *SPI_TxBuffer;
92
uint8_t SPI_TxBufferIndex = 0;
823 ingob 93
 
886 killagreg 94
uint8_t SPITransferCompleted, SPI_ChkSum;
95
uint8_t SPI_RxDataValid;
96
 
1078 killagreg 97
uint8_t SPI_CommandSequence[] = { SPI_CMD_USER, SPI_CMD_STICK, SPI_CMD_PARAMETER1, SPI_CMD_STICK, SPI_CMD_MISC, SPI_CMD_VERSION };
886 killagreg 98
uint8_t SPI_CommandCounter = 0;
99
 
100
/*********************************************/
101
/*  Initialize SPI interface to NaviCtrl     */
102
/*********************************************/
304 ingob 103
void SPI_MasterInit(void)
104
{
886 killagreg 105
        DDR_SPI |= (1<<DD_MOSI)|(1<<DD_SCK);    // Set MOSI and SCK output, all others input
106
        SLAVE_SELECT_DDR_PORT |= (1 << SPI_SLAVE_SELECT); // set Slave select port as output port
107
 
108
        SPCR = (1<<SPE)|(1<<MSTR)|(1<<SPR1)|(0<<SPR0)|(0<<SPIE);   // Enable SPI, Master, set clock rate fck/64
109
        SPSR = 0;//(1<<SPI2X);
110
 
111
        SLAVE_SELECT_PORT |=  (1 << SPI_SLAVE_SELECT); // Deselect Slave
112
 
113
        SPI_TxBuffer = (uint8_t *) &ToNaviCtrl; // set pointer to tx-buffer
114
        SPITransferCompleted = 1;
115
        // initialize data packet to NaviControl
116
        ToNaviCtrl.Sync1 = SPI_TXSYNCBYTE1;
117
        ToNaviCtrl.Sync2 = SPI_TXSYNCBYTE2;
118
 
119
        ToNaviCtrl.Command = SPI_CMD_USER;
911 killagreg 120
        ToNaviCtrl.IntegralNick = 0;
886 killagreg 121
        ToNaviCtrl.IntegralRoll = 0;
1078 killagreg 122
 
886 killagreg 123
        SPI_RxDataValid = 0;
1078 killagreg 124
 
125
        SPI_VersionInfo.Major = VERSION_MAJOR;
126
        SPI_VersionInfo.Minor = VERSION_MINOR;
127
        SPI_VersionInfo.Patch = VERSION_PATCH;
128
        SPI_VersionInfo.Compatible = NC_SPI_COMPATIBLE;
304 ingob 129
}
130
 
886 killagreg 131
 
132
/**********************************************************/
133
/*  Update Data transferd by the SPI from/to NaviCtrl     */
134
/**********************************************************/
135
void UpdateSPI_Buffer(void)
304 ingob 136
{
886 killagreg 137
        int16_t tmp;
138
        cli(); // stop all interrupts to avoid writing of new data during update of that packet.
823 ingob 139
 
886 killagreg 140
        // update content of packet to NaviCtrl
1180 killagreg 141
        ToNaviCtrl.IntegralNick = (int16_t)((10 * IntegralGyroNick) / GYRO_DEG_FACTOR); // convert to multiple of 0.1°
142
        ToNaviCtrl.IntegralRoll = (int16_t)((10 * IntegralGyroRoll) / GYRO_DEG_FACTOR); // convert to multiple of 0.1°
143
        ToNaviCtrl.GyroHeading  = (int16_t)((10 * YawGyroHeading)   / GYRO_DEG_FACTOR); // convert to multiple of 0.1°
144
        ToNaviCtrl.GyroNick = GyroNick;
145
        ToNaviCtrl.GyroRoll = GyroRoll;
146
        ToNaviCtrl.GyroYaw =  GyroYaw;
147
        ToNaviCtrl.AccNick =  ((int16_t) 10 * ACC_AMPLIFY * (NaviAccNick / NaviCntAcc)) / ACC_DEG_FACTOR; // convert to multiple of 0.1°
148
        ToNaviCtrl.AccRoll =  ((int16_t) 10 * ACC_AMPLIFY * (NaviAccRoll / NaviCntAcc)) / ACC_DEG_FACTOR; // convert to multiple of 0.1°
911 killagreg 149
        NaviCntAcc = 0; NaviAccNick = 0; NaviAccRoll = 0;
691 ingob 150
 
886 killagreg 151
        switch(ToNaviCtrl.Command)
152
        {
153
                case SPI_CMD_USER:
154
                        ToNaviCtrl.Param.Byte[0] = FCParam.UserParam1;
155
                        ToNaviCtrl.Param.Byte[1] = FCParam.UserParam2;
156
                        ToNaviCtrl.Param.Byte[2] = FCParam.UserParam3;
157
                        ToNaviCtrl.Param.Byte[3] = FCParam.UserParam4;
158
                        ToNaviCtrl.Param.Byte[4] = FCParam.UserParam5;
159
                        ToNaviCtrl.Param.Byte[5] = FCParam.UserParam6;
160
                        ToNaviCtrl.Param.Byte[6] = FCParam.UserParam7;
161
                        ToNaviCtrl.Param.Byte[7] = FCParam.UserParam8;
936 killagreg 162
                        ToNaviCtrl.Param.Byte[8] = MKFlags;
163
                        MKFlags &= ~(MKFLAG_CALIBRATE | MKFLAG_START); // calibrate and start are temporal states that are cleared immediately after transmitting
164
                        ToNaviCtrl.Param.Byte[9] = (uint8_t)UBat;
165
                        ToNaviCtrl.Param.Byte[10] = ParamSet.LowVoltageWarning;
166
                        ToNaviCtrl.Param.Byte[11] = GetActiveParamSet();
886 killagreg 167
                        break;
168
 
936 killagreg 169
                case SPI_CMD_PARAMETER1:
1078 killagreg 170
                        ToNaviCtrl.Param.Byte[0] = ParamSet.NaviGpsModeControl;     // Parameters for the Naviboard
171
                        ToNaviCtrl.Param.Byte[1] = ParamSet.NaviGpsGain;
172
                        ToNaviCtrl.Param.Byte[2] = ParamSet.NaviGpsP;
173
                        ToNaviCtrl.Param.Byte[3] = ParamSet.NaviGpsI;
174
                        ToNaviCtrl.Param.Byte[4] = ParamSet.NaviGpsD;
175
                        ToNaviCtrl.Param.Byte[5] = ParamSet.NaviGpsACC;
936 killagreg 176
                        ToNaviCtrl.Param.Byte[6] = ParamSet.NaviGpsMinSat;
177
                        ToNaviCtrl.Param.Byte[7] = ParamSet.NaviStickThreshold;
1078 killagreg 178
                        ToNaviCtrl.Param.Byte[8] = ParamSet.NaviOperatingRadius;
179
                        ToNaviCtrl.Param.Byte[9] = ParamSet.NaviWindCorrection;
180
            ToNaviCtrl.Param.Byte[10] = ParamSet.NaviSpeedCompensation;
181
            ToNaviCtrl.Param.Byte[11] = ParamSet.NaviAngleLimitation;
936 killagreg 182
                        break;
183
 
184
 
886 killagreg 185
                case SPI_CMD_STICK:
911 killagreg 186
                        tmp = PPM_in[ParamSet.ChannelAssignment[CH_GAS]];  if(tmp > 127) tmp = 127; else if(tmp < -128) tmp = -128;
886 killagreg 187
                        ToNaviCtrl.Param.Byte[0] = (int8_t) tmp;
188
                        tmp = PPM_in[ParamSet.ChannelAssignment[CH_YAW]]; if(tmp > 127) tmp = 127; else if(tmp < -128) tmp = -128;
189
                        ToNaviCtrl.Param.Byte[1] = (int8_t) tmp;
190
                        tmp = PPM_in[ParamSet.ChannelAssignment[CH_ROLL]]; if(tmp > 127) tmp = 127; else if(tmp < -128) tmp = -128;
191
                        ToNaviCtrl.Param.Byte[2] = (int8_t) tmp;
911 killagreg 192
                        tmp = PPM_in[ParamSet.ChannelAssignment[CH_NICK]]; if(tmp > 127) tmp = 127; else if(tmp < -128) tmp = -128;
886 killagreg 193
                        ToNaviCtrl.Param.Byte[3] = (int8_t) tmp;
194
                        ToNaviCtrl.Param.Byte[4] = (uint8_t) Poti1;
195
                        ToNaviCtrl.Param.Byte[5] = (uint8_t) Poti2;
196
                        ToNaviCtrl.Param.Byte[6] = (uint8_t) Poti3;
197
                        ToNaviCtrl.Param.Byte[7] = (uint8_t) Poti4;
198
                        ToNaviCtrl.Param.Byte[8] = (uint8_t) RC_Quality;
199
                        break;
200
 
1078 killagreg 201
                case SPI_CMD_MISC:
202
                        ToNaviCtrl.Param.Byte[0] = CompassCalState;
203
                        if(CompassCalState > 4)
204
                        { // jump from 5 to 0
205
                                CompassCalState  = 0;
886 killagreg 206
                        }
1180 killagreg 207
                        ToNaviCtrl.Param.Byte[1] = ParamSet.NaviPHLoginTime;
208
                        ToNaviCtrl.Param.Int[1]  = ReadingHeight; // at address of Byte 2 and 3
209
                        ToNaviCtrl.Param.Byte[4] = ParamSet.NaviGpsPLimit;
210
                        ToNaviCtrl.Param.Byte[5] = ParamSet.NaviGpsILimit;
211
                        ToNaviCtrl.Param.Byte[6] = ParamSet.NaviGpsDLimit;
886 killagreg 212
                        break;
1078 killagreg 213
 
214
                case SPI_CMD_VERSION:
215
                        ToNaviCtrl.Param.Byte[0] = SPI_VersionInfo.Major;
216
                        ToNaviCtrl.Param.Byte[1] = SPI_VersionInfo.Minor;
217
                        ToNaviCtrl.Param.Byte[2] = SPI_VersionInfo.Patch;
218
                        ToNaviCtrl.Param.Byte[3] = SPI_VersionInfo.Compatible;
1180 killagreg 219
                        ToNaviCtrl.Param.Byte[4] = BoardRelease;
1078 killagreg 220
                        break;
221
 
222
                default:
223
                        break;
886 killagreg 224
        }
225
 
226
 
227
        sei(); // enable all interrupts
228
 
229
        // analyze content of packet from NaviCtrl if valid
230
        if (SPI_RxDataValid)
231
        {
232
                // update gps controls
1180 killagreg 233
                if(abs(FromNaviCtrl.GPSStickNick) < 512 && abs(FromNaviCtrl.GPSStickRoll) < 512 && (ParamSet.GlobalConfig & CFG_GPS_ACTIVE))
886 killagreg 234
                {
1180 killagreg 235
                        GPSStickNick    = FromNaviCtrl.GPSStickNick;
236
                        GPSStickRoll    = FromNaviCtrl.GPSStickRoll;
886 killagreg 237
                }
238
                // update compass readings
239
                if(FromNaviCtrl.CompassHeading <= 360)
240
                {
241
                        CompassHeading = FromNaviCtrl.CompassHeading;
242
                }
243
                if(CompassHeading < 0) CompassOffCourse = 0;
244
                else CompassOffCourse = ((540 + CompassHeading - CompassCourse) % 360) - 180;
245
        // NaviCtrl wants to beep?
246
                if (FromNaviCtrl.BeepTime > BeepTime && !CompassCalState) BeepTime = FromNaviCtrl.BeepTime;
247
 
248
                switch (FromNaviCtrl.Command)
249
                {
1078 killagreg 250
                        case SPI_KALMAN:
1180 killagreg 251
                                FCParam.KalmanK = FromNaviCtrl.Param.Byte[0];
252
                                FCParam.KalmanMaxFusion = FromNaviCtrl.Param.Byte[1];
253
                                FCParam.KalmanMaxDrift = FromNaviCtrl.Param.Byte[2];
1078 killagreg 254
                                break;
255
 
886 killagreg 256
                        default:
257
                                break;
258
                }
259
        }
260
        else // no valid data from NaviCtrl
261
        {
262
                // disable GPS control
1180 killagreg 263
                GPSStickNick = 0;
264
                GPSStickRoll = 0;
886 killagreg 265
        }
304 ingob 266
}
267
 
886 killagreg 268
 
269
 
270
/*********************************************/
271
/*  Start Transmission of packet to NaviCtrl */
272
/*********************************************/
273
void SPI_StartTransmitPacket(void)
304 ingob 274
{
708 ingob 275
 
886 killagreg 276
        if (!SPITransferCompleted) return; // return immediately if transfer is in progress
277
        else // transmission was completed
278
        {
279
                SLAVE_SELECT_PORT &=  ~(1 << SPI_SLAVE_SELECT);  // Select slave
691 ingob 280
 
886 killagreg 281
                // cyclic commands
282
                ToNaviCtrl.Command = SPI_CommandSequence[SPI_CommandCounter++];
283
                if (SPI_CommandCounter >= sizeof(SPI_CommandSequence)) SPI_CommandCounter = 0;
284
 
936 killagreg 285
                SPITransferCompleted = 0; // transfer is in progress
886 killagreg 286
                UpdateSPI_Buffer();    // update data in ToNaviCtrl
287
 
288
                SPI_TxBufferIndex = 1; //proceed with 2nd byte
289
 
290
                // -- Debug-Output ---
291
                //----
292
                asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");            asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
293
                asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");            asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
294
                asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");            asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
295
                ToNaviCtrl.Chksum = ToNaviCtrl.Sync1; // init checksum
296
                SPDR = ToNaviCtrl.Sync1; // send first byte
297
        }
304 ingob 298
}
299
 
886 killagreg 300
//------------------------------------------------------
301
// This is the spi data transfer between FlightCtrl and NaviCtrl
302
// Every time this routine is called within the mainloop one byte of the packet to
303
// the NaviCtrl and one byte of the packet from the NaviCtrl is possible transfered
691 ingob 304
 
886 killagreg 305
void SPI_TransmitByte(void)
304 ingob 306
{
886 killagreg 307
        static SPI_RXState_t SPI_RXState = SPI_SYNC1;
308
        uint8_t rxdata;
309
        static uint8_t rxchksum;
823 ingob 310
 
886 killagreg 311
        if (SPITransferCompleted) return;  // return immediatly if transfer was completed
312
        if (!(SPSR & (1 << SPIF))) return; // return if no SPI-IRQ pending
313
        SendSPI = 4; // mait 4 * 0.102 ms for the next call of SPI_TransmitByte() in the main loop
823 ingob 314
 
886 killagreg 315
        SLAVE_SELECT_PORT |=  (1 << SPI_SLAVE_SELECT);   // DeselectSlave
823 ingob 316
 
886 killagreg 317
        rxdata = SPDR; // save spi data register
823 ingob 318
 
886 killagreg 319
        switch (SPI_RXState)
320
        {
321
                case SPI_SYNC1: // first sync byte
322
                        SPI_RxBufferIndex = 0; // set pointer to start of rx buffer
323
                        rxchksum = rxdata; // initialize checksum
324
                        if (rxdata == SPI_RXSYNCBYTE1 )
325
                        {       // 1st Syncbyte found
326
                                SPI_RXState  = SPI_SYNC2; // trigger to state for second sync byte
327
                        }
328
                        break;
823 ingob 329
 
886 killagreg 330
                case SPI_SYNC2: // second sync byte
331
                        if (rxdata == SPI_RXSYNCBYTE2)
332
                        {       // 2nd Syncbyte found
333
                                rxchksum += rxdata; // update checksum
334
                                SPI_RXState  = SPI_DATA;   // trigger to state for second sync byte
335
                        }
336
                        else // 2nd Syncbyte not found
337
                        {
338
                                SPI_RXState  = SPI_SYNC1; // jump back to 1st sync byte
339
                        }
340
                        break;
823 ingob 341
 
886 killagreg 342
                case SPI_DATA: // data bytes
343
                        SPI_RxBuffer[SPI_RxBufferIndex++] = rxdata;  // copy data byte to spi buffer
344
                        // if all bytes are received of a packet from the NaviCtrl
345
                        if (SPI_RxBufferIndex >= SPI_RXBUFFER_LEN)
346
                        {   // last byte transfered is the checksum of the packet
347
                                if (rxdata == rxchksum) // checksum matching?
348
                                {
349
                                        // copy SPI_RxBuffer -> FromFlightCtrl
350
                                        uint8_t *ptr = (uint8_t *)&FromNaviCtrl;
351
                                        cli();
352
                                        memcpy(ptr, (uint8_t *) SPI_RxBuffer, sizeof(FromNaviCtrl));
353
                                        sei();
354
                                        SPI_RxDataValid = 1;
1078 killagreg 355
                                        //DebugOut.Analog[18]++;
886 killagreg 356
                                }
357
                                else
358
                                {   // checksum does not match
1078 killagreg 359
                                        //DebugOut.Analog[17]++;
886 killagreg 360
                                        SPI_RxDataValid = 0; // reset valid flag
361
                                }
362
                                SPI_RXState  = SPI_SYNC1; // reset state sync
363
                        }
364
                        else // not all bytes transfered
365
                        {
366
                                rxchksum += rxdata; // update checksum
367
                        }
368
                        break;
369
        }// eof switch(SPI_RXState)
370
 
371
    // if still some bytes left for transmission to NaviCtrl
372
        if (SPI_TxBufferIndex < SPI_TXBUFFER_LEN)
373
        {
374
                SLAVE_SELECT_PORT &=  ~(1 << SPI_SLAVE_SELECT);  // SelectSlave
375
                asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
376
                asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
377
                asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
378
 
379
                SPDR = SPI_TxBuffer[SPI_TxBufferIndex]; // transmit byte
380
                ToNaviCtrl.Chksum += SPI_TxBuffer[SPI_TxBufferIndex]; // update checksum for everey byte that was sent
381
                SPI_TxBufferIndex++;
382
        }
383
        else
384
        {
385
                //Transfer of all bytes of the packet to NaviCtrl completed
386
                SPITransferCompleted = 1;
387
        }
304 ingob 388
}
389
 
390
 
391