Subversion Repositories FlightCtrl

Rev

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