Subversion Repositories FlightCtrl

Rev

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

Rev 885 Rev 886
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
-
 
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;
3
 
40
uint8_t SPI_TxBufferIndex = 0;
4
 
-
 
5
//struct str_ToNaviCtrl_Version   ToNaviCtrl_Version;
41
 
6
//struct str_FromNaviCtrl_Version   FromNaviCtrl_Version;
-
 
7
struct str_ToNaviCtrl   ToNaviCtrl;
42
uint8_t SPITransferCompleted, SPI_ChkSum;
8
struct str_FromNaviCtrl   FromNaviCtrl;
43
uint8_t SPI_RxDataValid;
9
 
-
 
10
unsigned char              SPI_BufferIndex;
44
 
-
 
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     */
13
volatile unsigned char     SPI_Buffer[sizeof(FromNaviCtrl)];
52
/*********************************************/
14
unsigned char *SPI_TX_Buffer;
53
void SPI_MasterInit(void)
15
 
54
{
-
 
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
                }
-
 
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;
-
 
-
 
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
65
   // -- Debug-Output ---
209
 
66
   //----
210
                // -- Debug-Output ---
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");
211
                //----
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");
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");
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");
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");
70
   ToNaviCtrl.Chksum = ToNaviCtrl.Sync1;
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");
71
   SPDR = ToNaviCtrl.Sync1;                  // Start transmission 
215
                ToNaviCtrl.Chksum = ToNaviCtrl.Sync1; // init checksum
72
//     SLAVE_SELECT_PORT |=  (1 << SPI_SLAVE_SELECT);   // DeselectSlave
216
                SPDR = ToNaviCtrl.Sync1; // send first byte
73
 
217
        }
74
}
218
}
75
 
219
 
76
//------------------------------------------------------
220
//------------------------------------------------------
77
//SIGNAL(SIG_SPI)
221
// This is the spi data transfer between FlightCtrl and NaviCtrl
-
 
222
// Every time this routine is called within the mainloop one byte of the packet to
-
 
223
// the NaviCtrl and one byte of the packet from the NaviCtrl is possible transfered
-
 
224
 
78
void SPI_TransmitByte(void)
225
void SPI_TransmitByte(void)
79
{
226
{
80
   static unsigned char SPI_RXState = 0;
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;
231
        if (SPITransferCompleted) return;  // return immediatly if transfer was completed
85
   if (!(SPSR & (1 << SPIF))) return;
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); 
-
 
89
  SLAVE_SELECT_PORT |=  (1 << SPI_SLAVE_SELECT);   // DeselectSlave
235
        SLAVE_SELECT_PORT |=  (1 << SPI_SLAVE_SELECT);   // DeselectSlave
90
 
236
 
91
  rxdata = SPDR;
237
        rxdata = SPDR; // save spi data register
-
 
238
 
92
  switch ( SPI_RXState)
239
        switch (SPI_RXState)
93
  {
240
        {
94
  case 0:
241
                case SPI_SYNC1: // first sync byte
95
           
-
 
96
                        SPI_RxBufferIndex = 0;
242
                        SPI_RxBufferIndex = 0; // set pointer to start of rx buffer
-
 
243
                        rxchksum = rxdata; // initialize checksum
97
                        //DebugOut.Analog[17]++;
244
                        if (rxdata == SPI_RXSYNCBYTE1 )
98
                        rxchksum = rxdata;  
245
                        {       // 1st Syncbyte found
99
                        if (rxdata == 0x81 )  { SPI_RXState  = 1;  }   // 1. Syncbyte ok 
246
                                SPI_RXState  = SPI_SYNC2; // trigger to state for second sync byte
100
                       
247
                        }
101
           break;
248
                        break;
102
 
249
 
103
   case 1:
-
 
104
                    if (rxdata == 0x55) { rxchksum += rxdata; SPI_RXState  = 2;  }   // 2. Syncbyte ok 
250
                case SPI_SYNC2: // second sync byte
105
                 else SPI_RXState  = 0;    
251
                        if (rxdata == SPI_RXSYNCBYTE2)
106
                        //DebugOut.Analog[18]++;
252
                        {       // 2nd Syncbyte found
107
           break;      
-
 
108
           
-
 
109
   case 2:
-
 
110
                   SPI_Buffer[SPI_RxBufferIndex++]= rxdata;             // get data
253
                                rxchksum += rxdata; // update checksum
111
           //DebugOut.Analog[19]++;
-
 
112
           if (SPI_RxBufferIndex >= sizeof(FromNaviCtrl))
254
                                SPI_RXState  = SPI_DATA;   // trigger to state for second sync byte
113
                   {  
255
                        }
114
                         
-
 
115
                if (rxdata == rxchksum)
256
                        else // 2nd Syncbyte not found
116
                        {
257
                        {
117
                  unsigned char *ptr = (unsigned char *)&FromNaviCtrl;
258
                                SPI_RXState  = SPI_SYNC1; // jump back to 1st sync byte
-
 
259
                        }
-
 
260
                        break;
118
     
261
 
-
 
262
                case SPI_DATA: // data bytes
-
 
263
                        SPI_RxBuffer[SPI_RxBufferIndex++] = rxdata;  // copy data byte to spi buffer
-
 
264
                        // if all bytes are received of a packet from the NaviCtrl
-
 
265
                        if (SPI_RxBufferIndex >= SPI_RXBUFFER_LEN)
-
 
266
                        {   // last byte transfered is the checksum of the packet
-
 
267
                                if (rxdata == rxchksum) // checksum matching?
-
 
268
                                {
-
 
269
                                        // copy SPI_RxBuffer -> FromFlightCtrl
-
 
270
                                        uint8_t *ptr = (uint8_t *)&FromNaviCtrl;
-
 
271
                                        cli();
119
                          memcpy(ptr, (unsigned char *) SPI_Buffer,  sizeof(SPI_Buffer));
272
                                        memcpy(ptr, (uint8_t *) SPI_RxBuffer, sizeof(FromNaviCtrl));
120
                         
273
                                        sei();
121
                          SPI_RxDataValid = 1;
274
                                        SPI_RxDataValid = 1;
-
 
275
                                        DebugOut.Analog[18]++;
122
                        }
276
                                }
-
 
277
                                else
-
 
278
                                {   // checksum does not match
-
 
279
                                        DebugOut.Analog[17]++;
123
                        else SPI_RxDataValid = 0;
280
                                        SPI_RxDataValid = 0; // reset valid flag
124
                       
281
                                }
125
                        SPI_RXState  = 0;  
282
                                SPI_RXState  = SPI_SYNC1; // reset state sync
126
                   }
283
                        }
127
                  else rxchksum += rxdata;
284
                        else // not all bytes transfered
128
        break;   
285
                        {
-
 
286
                                rxchksum += rxdata; // update checksum
129
         
287
                        }
130
  }            
288
                        break;
-
 
289
        }// eof switch(SPI_RXState)
131
 
290
 
-
 
291
    // if still some bytes left for transmission to NaviCtrl
132
   if (SPI_BufferIndex < sizeof(ToNaviCtrl))  
292
        if (SPI_TxBufferIndex < SPI_TXBUFFER_LEN)
133
     {
293
        {
134
           SLAVE_SELECT_PORT &=  ~(1 << SPI_SLAVE_SELECT);  // SelectSlave
294
                SLAVE_SELECT_PORT &=  ~(1 << SPI_SLAVE_SELECT);  // SelectSlave
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");
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");
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");
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");
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");
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");
138
           
298
 
139
           SPDR = SPI_TX_Buffer[SPI_BufferIndex];
299
                SPDR = SPI_TxBuffer[SPI_TxBufferIndex]; // transmit byte
140
           ToNaviCtrl.Chksum += SPI_TX_Buffer[SPI_BufferIndex];
300
                ToNaviCtrl.Chksum += SPI_TxBuffer[SPI_TxBufferIndex]; // update checksum for everey byte that was sent
141
        //   SLAVE_SELECT_PORT |=  (1 << SPI_SLAVE_SELECT);   // DeselectSlave
301
                SPI_TxBufferIndex++;
142
 
302
        }
-
 
303
        else
143
         }
304
        {
-
 
305
                //Transfer of all bytes of the packet to NaviCtrl completed
144
         else SPITransferCompleted = 1;  
306
                SPITransferCompleted = 1;
145
       
307
        }
146
         SPI_BufferIndex++;
-
 
147
}
308
}
148
 
309
 
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
  {
-
 
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
          {
310
 
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;
-
 
237
          }
-
 
238
  }
-
 
239
  else
-
 
240
  {
-
 
241
//    KompassValue = 0;
-
 
242
//    KompassRichtung = 0;
-
 
243
       
-
 
244
        GPS_Nick = 0;
-
 
245
    GPS_Roll = 0;
-
 
246
  }
-
 
247
}
-
 
248
 
-
 
249
#endif
311
#endif //USE_SPI_COMMUNICATION
250
 
312
 
251
 
313
 
252
 
314