Subversion Repositories FlightCtrl

Rev

Rev 885 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 885 Rev 886
Line 1... Line 1...
1
// ######################## SPI - FlightCtrl ###################
1
// ######################## SPI - FlightCtrl ###################
-
 
2
#include <avr/io.h>
-
 
3
#include <avr/interrupt.h>
-
 
4
#include <string.h>
-
 
5
#include <stdlib.h>
-
 
6
#include "_Settings.h"
-
 
7
#include "spi.h"
-
 
8
#include "fc.h"
-
 
9
#include "rc.h"
-
 
10
#include "eeprom.h"
2
#include "main.h"
11
#include "uart.h"
-
 
12
#include "timer0.h"
-
 
13
 
-
 
14
#define SPI_TXSYNCBYTE1 0xAA
-
 
15
#define SPI_TXSYNCBYTE2 0x83
-
 
16
#define SPI_RXSYNCBYTE1 0x81
-
 
17
#define SPI_RXSYNCBYTE2 0x55
Line -... Line 18...
-
 
18
 
-
 
19
typedef enum
-
 
20
{
-
 
21
        SPI_SYNC1,
-
 
22
        SPI_SYNC2,
-
 
23
        SPI_DATA
-
 
24
} SPI_RXState_t;
-
 
25
 
-
 
26
 
-
 
27
// data exchange packets to and From NaviCtrl
-
 
28
ToNaviCtrl_t    ToNaviCtrl;
-
 
29
FromNaviCtrl_t  FromNaviCtrl;
-
 
30
 
-
 
31
// rx packet buffer
-
 
32
#define SPI_RXBUFFER_LEN sizeof(FromNaviCtrl)
-
 
33
uint8_t SPI_RxBuffer[SPI_RXBUFFER_LEN];
-
 
34
uint8_t SPI_RxBufferIndex = 0;
-
 
35
uint8_t SPI_RxBuffer_Request = 0;
-
 
36
 
-
 
37
// tx packet buffer
-
 
38
#define SPI_TXBUFFER_LEN sizeof(ToNaviCtrl)
-
 
39
uint8_t *SPI_TxBuffer;
Line 3... Line 40...
3
 
40
uint8_t SPI_TxBufferIndex = 0;
4
 
-
 
5
//struct str_ToNaviCtrl_Version   ToNaviCtrl_Version;
41
 
6
//struct str_FromNaviCtrl_Version   FromNaviCtrl_Version;
-
 
Line 7... Line 42...
7
struct str_ToNaviCtrl   ToNaviCtrl;
42
uint8_t SPITransferCompleted, SPI_ChkSum;
8
struct str_FromNaviCtrl   FromNaviCtrl;
43
uint8_t SPI_RxDataValid;
Line 9... Line -...
9
 
-
 
10
unsigned char              SPI_BufferIndex;
44
 
Line -... Line 45...
-
 
45
uint8_t SPI_CommandSequence[] = { SPI_CMD_USER, SPI_CMD_STICK, SPI_CMD_USER, SPI_CMD_STICK, SPI_CMD_CAL_COMPASS };
11
unsigned char              SPI_RxBufferIndex;
46
uint8_t SPI_CommandCounter = 0;
-
 
47
 
12
 
48
#ifdef USE_SPI_COMMUNICATION
-
 
49
 
-
 
50
/*********************************************/
-
 
51
/*  Initialize SPI interface to NaviCtrl     */
Line 13... Line 52...
13
volatile unsigned char     SPI_Buffer[sizeof(FromNaviCtrl)];
52
/*********************************************/
14
unsigned char *SPI_TX_Buffer;
53
void SPI_MasterInit(void)
Line 15... Line 54...
15
 
54
{
Line -... Line 55...
-
 
55
        DDR_SPI |= (1<<DD_MOSI)|(1<<DD_SCK);    // Set MOSI and SCK output, all others input
-
 
56
        SLAVE_SELECT_DDR_PORT |= (1 << SPI_SLAVE_SELECT); // set Slave select port as output port
-
 
57
 
-
 
58
        SPCR = (1<<SPE)|(1<<MSTR)|(1<<SPR1)|(0<<SPR0)|(0<<SPIE);   // Enable SPI, Master, set clock rate fck/64
-
 
59
        SPSR = 0;//(1<<SPI2X);
-
 
60
 
-
 
61
        SLAVE_SELECT_PORT |=  (1 << SPI_SLAVE_SELECT); // Deselect Slave
-
 
62
 
-
 
63
        SPI_TxBuffer = (uint8_t *) &ToNaviCtrl; // set pointer to tx-buffer
-
 
64
        SPITransferCompleted = 1;
-
 
65
        // initialize data packet to NaviControl
-
 
66
        ToNaviCtrl.Sync1 = SPI_TXSYNCBYTE1;
-
 
67
        ToNaviCtrl.Sync2 = SPI_TXSYNCBYTE2;
-
 
68
 
-
 
69
        ToNaviCtrl.Command = SPI_CMD_USER;
16
unsigned char SPITransferCompleted, SPI_ChkSum;
70
        ToNaviCtrl.IntegralPitch = 0;
17
unsigned char SPI_RxDataValid;
71
        ToNaviCtrl.IntegralRoll = 0;
18
 
72
        SPI_RxDataValid = 0;
-
 
73
}
19
unsigned char SPI_CommandSequence[] = { SPI_CMD_USER, SPI_CMD_STICK, SPI_CMD_USER, SPI_CMD_STICK, SPI_CMD_CAL_COMPASS };
74
 
-
 
75
 
-
 
76
/**********************************************************/
-
 
77
/*  Update Data transferd by the SPI from/to NaviCtrl     */
-
 
78
/**********************************************************/
-
 
79
void UpdateSPI_Buffer(void)
-
 
80
{
-
 
81
        int16_t tmp;
-
 
82
        cli(); // stop all interrupts to avoid writing of new data during update of that packet.
-
 
83
 
-
 
84
        // update content of packet to NaviCtrl
-
 
85
        ToNaviCtrl.IntegralPitch = (int16_t) (IntegralPitch / 108);
-
 
86
        ToNaviCtrl.IntegralRoll  = (int16_t) (IntegralRoll  / 108);
-
 
87
        ToNaviCtrl.GyroHeading = YawGyroHeading / YAW_GYRO_DEG_FACTOR;
-
 
88
        ToNaviCtrl.GyroPitch = Reading_GyroPitch;
-
 
89
        ToNaviCtrl.GyroRoll = Reading_GyroRoll;
-
 
90
        ToNaviCtrl.GyroYaw = Reading_GyroYaw;
20
unsigned char SPI_CommandCounter = 0;
91
        ToNaviCtrl.AccPitch = (int16_t) ACC_AMPLIFY * (NaviAccPitch / NaviCntAcc);
-
 
92
        ToNaviCtrl.AccRoll =  (int16_t) ACC_AMPLIFY * (NaviAccRoll / NaviCntAcc);
-
 
93
        NaviCntAcc = 0; NaviAccPitch = 0; NaviAccRoll = 0;
-
 
94
 
-
 
95
        switch(ToNaviCtrl.Command)
-
 
96
        {
-
 
97
                case SPI_CMD_USER:
-
 
98
                        ToNaviCtrl.Param.Byte[0] = FCParam.UserParam1;
21
 
99
                        ToNaviCtrl.Param.Byte[1] = FCParam.UserParam2;
-
 
100
                        ToNaviCtrl.Param.Byte[2] = FCParam.UserParam3;
-
 
101
                        ToNaviCtrl.Param.Byte[3] = FCParam.UserParam4;
-
 
102
                        ToNaviCtrl.Param.Byte[4] = FCParam.UserParam5;
-
 
103
                        ToNaviCtrl.Param.Byte[5] = FCParam.UserParam6;
-
 
104
                        ToNaviCtrl.Param.Byte[6] = FCParam.UserParam7;
22
#ifdef USE_SPI_COMMUNICATION
105
                        ToNaviCtrl.Param.Byte[7] = FCParam.UserParam8;
-
 
106
                        break;
-
 
107
 
-
 
108
                case SPI_CMD_STICK:
-
 
109
                        tmp = PPM_in[ParamSet.ChannelAssignment[CH_THRUST]];  if(tmp > 127) tmp = 127; else if(tmp < -128) tmp = -128;
-
 
110
                        ToNaviCtrl.Param.Byte[0] = (int8_t) tmp;
-
 
111
                        tmp = PPM_in[ParamSet.ChannelAssignment[CH_YAW]]; if(tmp > 127) tmp = 127; else if(tmp < -128) tmp = -128;
23
 
112
                        ToNaviCtrl.Param.Byte[1] = (int8_t) tmp;
-
 
113
                        tmp = PPM_in[ParamSet.ChannelAssignment[CH_ROLL]]; if(tmp > 127) tmp = 127; else if(tmp < -128) tmp = -128;
-
 
114
                        ToNaviCtrl.Param.Byte[2] = (int8_t) tmp;
24
//------------------------------------------------------
115
                        tmp = PPM_in[ParamSet.ChannelAssignment[CH_PITCH]]; if(tmp > 127) tmp = 127; else if(tmp < -128) tmp = -128;
25
void SPI_MasterInit(void)
116
                        ToNaviCtrl.Param.Byte[3] = (int8_t) tmp;
-
 
117
                        ToNaviCtrl.Param.Byte[4] = (uint8_t) Poti1;
-
 
118
                        ToNaviCtrl.Param.Byte[5] = (uint8_t) Poti2;
26
{
119
                        ToNaviCtrl.Param.Byte[6] = (uint8_t) Poti3;
-
 
120
                        ToNaviCtrl.Param.Byte[7] = (uint8_t) Poti4;
-
 
121
                        ToNaviCtrl.Param.Byte[8] = (uint8_t) RC_Quality;
-
 
122
                        break;
-
 
123
 
-
 
124
                case SPI_CMD_CAL_COMPASS:
-
 
125
                        if(CompassCalState > 5)
-
 
126
                        {
-
 
127
                                CompassCalState = 0;
-
 
128
                                ToNaviCtrl.Param.Byte[0] = 5;
27
  DDR_SPI |= (1<<DD_MOSI)|(1<<DD_SCK);    // Set MOSI and SCK output, all others input 
129
                        }
28
  SLAVE_SELECT_DDR_PORT |= (1 << SPI_SLAVE_SELECT);
130
                        else
29
   
131
                        {
-
 
132
                                ToNaviCtrl.Param.Byte[0] = CompassCalState;
-
 
133
                        }
-
 
134
                        break;
-
 
135
        }
-
 
136
 
-
 
137
 
-
 
138
        sei(); // enable all interrupts
-
 
139
 
-
 
140
        // analyze content of packet from NaviCtrl if valid
-
 
141
        if (SPI_RxDataValid)
30
  SPCR = (1<<SPE)|(1<<MSTR)|(1<<SPR1)|(0<<SPR0)|(0<<SPIE);   // Enable SPI, Master, set clock rate fck/64 
142
        {
-
 
143
                // update gps controls
-
 
144
                if(abs(FromNaviCtrl.GPS_Pitch) < 512 && abs(FromNaviCtrl.GPS_Roll) < 512 && (ParamSet.GlobalConfig & CFG_GPS_ACTIVE))
-
 
145
                {
-
 
146
                        GPS_Pitch = FromNaviCtrl.GPS_Pitch;
-
 
147
                        GPS_Roll  = FromNaviCtrl.GPS_Roll;
31
  SPSR = 0;//(1<<SPI2X);
148
                }
-
 
149
                // update compass readings
32
 
150
                if(FromNaviCtrl.CompassHeading <= 360)
33
  SLAVE_SELECT_PORT |=  (1 << SPI_SLAVE_SELECT);
151
                {
-
 
152
                        CompassHeading = FromNaviCtrl.CompassHeading;
-
 
153
                }
-
 
154
                if(CompassHeading < 0) CompassOffCourse = 0;
34
  SPITransferCompleted = 1;
155
                else CompassOffCourse = ((540 + CompassHeading - CompassCourse) % 360) - 180;
-
 
156
        // NaviCtrl wants to beep?
-
 
157
                if (FromNaviCtrl.BeepTime > BeepTime && !CompassCalState) BeepTime = FromNaviCtrl.BeepTime;
-
 
158
 
-
 
159
                switch (FromNaviCtrl.Command)
-
 
160
                {
-
 
161
                        case  SPI_CMD_OSD_DATA:
-
 
162
                                //                                ToFlightCtrl.Param.Byte[0] = OsdBar;
35
 
163
                                //                                ToFlightCtrl.Param.Int[1]  = Distance;
-
 
164
                                break;
-
 
165
 
-
 
166
                        case  SPI_CMD_GPS_POS:
-
 
167
                                //                                ToFlightCtrl.Param.Long[0]  = GPS_Data.Longitude;
-
 
168
                                //                                ToFlightCtrl.Param.Long[1]  = GPS_Data.Latitude;
-
 
169
                                break;
-
 
170
 
-
 
171
                        case  SPI_CMD_GPS_TARGET:
-
 
172
                                //                                ToFlightCtrl.Param.Long[0]  = GPS_Data.TargetLongitude;
-
 
173
                                //                                ToFlightCtrl.Param.Long[1]  = GPS_Data.TargetLatitude;
-
 
174
                                break;
-
 
175
 
36
  //SPDR = 0x00;  // dummy write
176
                        default:
-
 
177
                                break;
37
 
178
                }
Line -... Line 179...
-
 
179
        }
-
 
180
        else // no valid data from NaviCtrl
-
 
181
        {
-
 
182
                // disable GPS control
38
  ToNaviCtrl.Sync1 = 0xAA;
183
                GPS_Pitch = 0;
39
  ToNaviCtrl.Sync2 = 0x83;
184
                GPS_Roll = 0;
40
 
185
        }
41
  ToNaviCtrl.Command = SPI_CMD_USER;
-
 
42
  ToNaviCtrl.IntegralNick = 0;
-
 
43
  ToNaviCtrl.IntegralRoll = 0;
-
 
44
  SPI_RxDataValid = 0;
-
 
45
}
-
 
46
 
-
 
47
//------------------------------------------------------
-
 
48
void SPI_StartTransmitPacket(void)
-
 
49
{
-
 
50
   //if ((SLAVE_SELECT_PORT & (1 << SPI_SLAVE_SELECT)) == 0) return;    // transfer of prev. packet not completed
-
 
51
   if (!SPITransferCompleted) return;
-
 
52
//   _delay_us(30); 
-
 
53
   
-
 
54
   SLAVE_SELECT_PORT &=  ~(1 << SPI_SLAVE_SELECT);  // SelectSlave
-
 
55
   SPI_TX_Buffer = (unsigned char *) &ToNaviCtrl;
-
 
56
   
-
 
57
   ToNaviCtrl.Command = SPI_CommandSequence[SPI_CommandCounter++];
-
 
58
   if (SPI_CommandCounter >= sizeof(SPI_CommandSequence)) SPI_CommandCounter = 0;
-
 
59
   
-
 
60
   SPITransferCompleted = 0;
-
 
61
   UpdateSPI_Buffer();                              // update buffer
-
 
62
 
-
 
63
   SPI_BufferIndex = 1;
-
 
Line -... Line 186...
-
 
186
}
-
 
187
 
-
 
188
 
-
 
189
 
-
 
190
/*********************************************/
-
 
191
/*  Start Transmission of packet to NaviCtrl */
-
 
192
/*********************************************/
-
 
193
void SPI_StartTransmitPacket(void)
-
 
194
{
-
 
195
 
-
 
196
        if (!SPITransferCompleted) return; // return immediately if transfer is in progress
-
 
197
        else // transmission was completed
-
 
198
        {
-
 
199
                SLAVE_SELECT_PORT &=  ~(1 << SPI_SLAVE_SELECT);  // Select slave
-
 
200
 
-
 
201
                // cyclic commands
-
 
202
                ToNaviCtrl.Command = SPI_CommandSequence[SPI_CommandCounter++];
-
 
203
                if (SPI_CommandCounter >= sizeof(SPI_CommandSequence)) SPI_CommandCounter = 0;
-
 
204
 
-
 
205
                SPITransferCompleted = 0; // tranfer is in progress
-
 
206
                UpdateSPI_Buffer();    // update data in ToNaviCtrl
-
 
207
 
64
  //ebugOut.Analog[16]++; 
208
                SPI_TxBufferIndex = 1; //proceed with 2nd byte
Line 65... Line 209...
65
   // -- Debug-Output ---
209
 
66
   //----
210
                // -- Debug-Output ---
-
 
211
                //----
-
 
212
                asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");            asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
-
 
213
                asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");            asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
67
   asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");         asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
214
                asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");            asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
68
   asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");         asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
215
                ToNaviCtrl.Chksum = ToNaviCtrl.Sync1; // init checksum
69
   asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");         asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
216
                SPDR = ToNaviCtrl.Sync1; // send first byte
70
   ToNaviCtrl.Chksum = ToNaviCtrl.Sync1;
217
        }
71
   SPDR = ToNaviCtrl.Sync1;                  // Start transmission 
218
}
72
//     SLAVE_SELECT_PORT |=  (1 << SPI_SLAVE_SELECT);   // DeselectSlave
219
 
73
 
220
//------------------------------------------------------
74
}
221
// This is the spi data transfer between FlightCtrl and NaviCtrl
75
 
222
// Every time this routine is called within the mainloop one byte of the packet to
76
//------------------------------------------------------
223
// the NaviCtrl and one byte of the packet from the NaviCtrl is possible transfered
77
//SIGNAL(SIG_SPI)
-
 
78
void SPI_TransmitByte(void)
224
 
79
{
225
void SPI_TransmitByte(void)
80
   static unsigned char SPI_RXState = 0;
226
{
-
 
227
        static SPI_RXState_t SPI_RXState = SPI_SYNC1;
81
   unsigned char rxdata;
228
        uint8_t rxdata;
82
   static unsigned char rxchksum;
229
        static uint8_t rxchksum;
83
   
230
 
84
   if (SPITransferCompleted) return;
-
 
85
   if (!(SPSR & (1 << SPIF))) return;
231
        if (SPITransferCompleted) return;  // return immediatly if transfer was completed
-
 
232
        if (!(SPSR & (1 << SPIF))) return; // return if no SPI-IRQ pending
86
  SendSPI = 4;
233
        SendSPI = 4; // mait 4 * 0.102 ms for the next call of SPI_TransmitByte() in the main loop
87
   
234
 
88
//   _delay_us(30); 
235
        SLAVE_SELECT_PORT |=  (1 << SPI_SLAVE_SELECT);   // DeselectSlave
89
  SLAVE_SELECT_PORT |=  (1 << SPI_SLAVE_SELECT);   // DeselectSlave
236
 
90
 
237
        rxdata = SPDR; // save spi data register
91
  rxdata = SPDR;
238
 
92
  switch ( SPI_RXState)
-
 
93
  {
239
        switch (SPI_RXState)
94
  case 0:
240
        {
95
           
241
                case SPI_SYNC1: // first sync byte
96
                        SPI_RxBufferIndex = 0;
-
 
97
                        //DebugOut.Analog[17]++;
-
 
98
                        rxchksum = rxdata;  
-
 
99
                        if (rxdata == 0x81 )  { SPI_RXState  = 1;  }   // 1. Syncbyte ok 
242
                        SPI_RxBufferIndex = 0; // set pointer to start of rx buffer
100
                       
-
 
101
           break;
243
                        rxchksum = rxdata; // initialize checksum
102
 
244
                        if (rxdata == SPI_RXSYNCBYTE1 )
103
   case 1:
-
 
104
                    if (rxdata == 0x55) { rxchksum += rxdata; SPI_RXState  = 2;  }   // 2. Syncbyte ok 
245
                        {       // 1st Syncbyte found
105
                 else SPI_RXState  = 0;    
246
                                SPI_RXState  = SPI_SYNC2; // trigger to state for second sync byte
106
                        //DebugOut.Analog[18]++;
247
                        }
-
 
248
                        break;
-
 
249
 
107
           break;      
250
                case SPI_SYNC2: // second sync byte
-
 
251
                        if (rxdata == SPI_RXSYNCBYTE2)
-
 
252
                        {       // 2nd Syncbyte found
-
 
253
                                rxchksum += rxdata; // update checksum
-
 
254
                                SPI_RXState  = SPI_DATA;   // trigger to state for second sync byte
-
 
255
                        }
-
 
256
                        else // 2nd Syncbyte not found
-
 
257
                        {
-
 
258
                                SPI_RXState  = SPI_SYNC1; // jump back to 1st sync byte
-
 
259
                        }
-
 
260
                        break;
108
           
261
 
109
   case 2:
262
                case SPI_DATA: // data bytes
110
                   SPI_Buffer[SPI_RxBufferIndex++]= rxdata;             // get data
263
                        SPI_RxBuffer[SPI_RxBufferIndex++] = rxdata;  // copy data byte to spi buffer
-
 
264
                        // if all bytes are received of a packet from the NaviCtrl
111
           //DebugOut.Analog[19]++;
265
                        if (SPI_RxBufferIndex >= SPI_RXBUFFER_LEN)
-
 
266
                        {   // last byte transfered is the checksum of the packet
-
 
267
                                if (rxdata == rxchksum) // checksum matching?
-
 
268
                                {
112
           if (SPI_RxBufferIndex >= sizeof(FromNaviCtrl))
269
                                        // copy SPI_RxBuffer -> FromFlightCtrl
113
                   {  
270
                                        uint8_t *ptr = (uint8_t *)&FromNaviCtrl;
114
                         
271
                                        cli();
115
                if (rxdata == rxchksum)
272
                                        memcpy(ptr, (uint8_t *) SPI_RxBuffer, sizeof(FromNaviCtrl));
116
                        {
273
                                        sei();
117
                  unsigned char *ptr = (unsigned char *)&FromNaviCtrl;
274
                                        SPI_RxDataValid = 1;
-
 
275
                                        DebugOut.Analog[18]++;
118
     
276
                                }
119
                          memcpy(ptr, (unsigned char *) SPI_Buffer,  sizeof(SPI_Buffer));
277
                                else
-
 
278
                                {   // checksum does not match
120
                         
279
                                        DebugOut.Analog[17]++;
-
 
280
                                        SPI_RxDataValid = 0; // reset valid flag
121
                          SPI_RxDataValid = 1;
281
                                }
122
                        }
282
                                SPI_RXState  = SPI_SYNC1; // reset state sync
123
                        else SPI_RxDataValid = 0;
283
                        }
124
                       
284
                        else // not all bytes transfered
125
                        SPI_RXState  = 0;  
285
                        {
126
                   }
286
                                rxchksum += rxdata; // update checksum
127
                  else rxchksum += rxdata;
287
                        }
128
        break;   
288
                        break;
129
         
289
        }// eof switch(SPI_RXState)
130
  }            
290
 
131
 
291
    // if still some bytes left for transmission to NaviCtrl
-
 
292
        if (SPI_TxBufferIndex < SPI_TXBUFFER_LEN)
132
   if (SPI_BufferIndex < sizeof(ToNaviCtrl))  
293
        {
-
 
294
                SLAVE_SELECT_PORT &=  ~(1 << SPI_SLAVE_SELECT);  // SelectSlave
133
     {
295
                asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
134
           SLAVE_SELECT_PORT &=  ~(1 << SPI_SLAVE_SELECT);  // SelectSlave
296
                asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
135
           asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");         asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
-
 
136
           asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");         asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
297
                asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
Line 137... Line -...
137
           asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");         asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
-
 
138
           
-
 
139
           SPDR = SPI_TX_Buffer[SPI_BufferIndex];
-
 
140
           ToNaviCtrl.Chksum += SPI_TX_Buffer[SPI_BufferIndex];
-
 
141
        //   SLAVE_SELECT_PORT |=  (1 << SPI_SLAVE_SELECT);   // DeselectSlave
-
 
142
 
-
 
143
         }
-
 
144
         else SPITransferCompleted = 1;  
-
 
145
       
-
 
146
         SPI_BufferIndex++;
-
 
147
}
-
 
148
 
-
 
149
 
-
 
150
//------------------------------------------------------
-
 
151
void UpdateSPI_Buffer(void)
-
 
152
{
-
 
153
  static unsigned char i =0;
-
 
154
  signed int tmp;
-
 
155
  cli();
-
 
156
 
-
 
157
  ToNaviCtrl.IntegralNick = (int) (IntegralNick / 108);
-
 
158
  ToNaviCtrl.IntegralRoll = (int) (IntegralRoll / 108);
-
 
159
  ToNaviCtrl.GyroCompass = ErsatzKompass / GIER_GRAD_FAKTOR;
-
 
160
  ToNaviCtrl.AccNick = (int) ACC_AMPLIFY * (NaviAccNick / NaviCntAcc);
-
 
161
  ToNaviCtrl.AccRoll = (int) ACC_AMPLIFY * (NaviAccRoll / NaviCntAcc);
-
 
162
  NaviCntAcc = 0; NaviAccNick = 0; NaviAccRoll = 0;
-
 
163
//  ToNaviCtrl.User8 = Parameter_UserParam8;
-
 
164
//  ToNaviCtrl.CalState = WinkelOut.CalcState;
-
 
165
 
-
 
166
   switch(ToNaviCtrl.Command)  // 
-
 
167
   {
-
 
168
         case SPI_CMD_USER:
-
 
169
                                ToNaviCtrl.Param.Byte[0] = Parameter_UserParam1;
-
 
170
                                ToNaviCtrl.Param.Byte[1] = Parameter_UserParam2;
-
 
171
                                ToNaviCtrl.Param.Byte[2] = Parameter_UserParam3;
-
 
172
                                ToNaviCtrl.Param.Byte[3] = Parameter_UserParam4;
-
 
173
                                ToNaviCtrl.Param.Byte[4] = Parameter_UserParam5;
-
 
174
                                ToNaviCtrl.Param.Byte[5] = Parameter_UserParam6;
-
 
175
                                ToNaviCtrl.Param.Byte[6] = Parameter_UserParam7;
-
 
176
            break;
-
 
177
 
-
 
178
         case SPI_CMD_STICK:
-
 
179
                tmp = PPM_in[EE_Parameter.Kanalbelegung[K_GAS]];  if(tmp > 127) tmp = 127; else if(tmp < -127) tmp = -127;
-
 
180
                                ToNaviCtrl.Param.Byte[0] = (char) tmp;
-
 
181
                tmp = PPM_in[EE_Parameter.Kanalbelegung[K_GIER]]; if(tmp > 127) tmp = 127; else if(tmp < -127) tmp = -127;
-
 
182
                                ToNaviCtrl.Param.Byte[1] = (char) tmp;
-
 
183
                tmp = PPM_in[EE_Parameter.Kanalbelegung[K_ROLL]]; if(tmp > 127) tmp = 127; else if(tmp < -127) tmp = -127;
-
 
184
                                ToNaviCtrl.Param.Byte[2] = (char) tmp;
-
 
185
                tmp = PPM_in[EE_Parameter.Kanalbelegung[K_NICK]]; if(tmp > 127) tmp = 127; else if(tmp < -127) tmp = -127;
-
 
186
                                ToNaviCtrl.Param.Byte[3] = (char) tmp;
-
 
187
                                ToNaviCtrl.Param.Byte[4] = (unsigned char) Poti1;
-
 
188
                                ToNaviCtrl.Param.Byte[5] = (unsigned char) Poti2;
-
 
189
                                ToNaviCtrl.Param.Byte[6] = (unsigned char) Poti3;
-
 
190
                    ToNaviCtrl.Param.Byte[7] = (unsigned char) Poti4;
-
 
191
                    ToNaviCtrl.Param.Byte[8] = (unsigned char) SenderOkay;
-
 
192
 
-
 
193
            break;
-
 
194
         case SPI_CMD_CAL_COMPASS:
-
 
195
                if(WinkelOut.CalcState > 5)  
-
 
196
                  {
-
 
197
                    WinkelOut.CalcState = 0;    
-
 
198
                    ToNaviCtrl.Param.Byte[0] = 5;
-
 
199
                  }  
-
 
200
                                else ToNaviCtrl.Param.Byte[0] = WinkelOut.CalcState;
-
 
201
            break;
-
 
202
   }
-
 
203
 
-
 
204
  sei();
-
 
205
     
-
 
206
  if (SPI_RxDataValid)
-
 
207
  {
298
 
208
   if(abs(FromNaviCtrl.GPS_Nick) < 512 && abs(FromNaviCtrl.GPS_Roll) < 512 && (EE_Parameter.GlobalConfig & CFG_GPS_AKTIV))
-
 
209
   {
-
 
210
    GPS_Nick = FromNaviCtrl.GPS_Nick;
-
 
211
    GPS_Roll = FromNaviCtrl.GPS_Roll;
-
 
212
   }
-
 
213
    if(FromNaviCtrl.CompassValue <= 360)   KompassValue = FromNaviCtrl.CompassValue;
-
 
214
    KompassRichtung = ((540 + KompassValue - KompassStartwert) % 360) - 180;
-
 
215
 
-
 
216
    if(FromNaviCtrl.BeepTime > beeptime && !WinkelOut.CalcState) beeptime = FromNaviCtrl.BeepTime;
-
 
217
       
-
 
218
          switch (FromNaviCtrl.Command)
-
 
219
          {
-
 
220
            case  SPI_CMD_OSD_DATA:
-
 
221
//                                ToFlightCtrl.Param.Byte[0] = OsdBar;
-
 
222
//                                ToFlightCtrl.Param.Int[1]  = Distance;
-
 
223
                  break;
-
 
224
 
-
 
225
            case  SPI_CMD_GPS_POS:
-
 
226
//                                ToFlightCtrl.Param.Long[0]  = GPS_Data.Longitude;
-
 
227
//                                ToFlightCtrl.Param.Long[1]  = GPS_Data.Latitude;
-
 
228
                  break;
-
 
229
 
-
 
230
            case  SPI_CMD_GPS_TARGET:
-
 
231
//                                ToFlightCtrl.Param.Long[0]  = GPS_Data.TargetLongitude;
-
 
232
//                                ToFlightCtrl.Param.Long[1]  = GPS_Data.TargetLatitude;
-
 
233
                  break;
-
 
234
 
-
 
235
                default:
-
 
236
                  break;
-