Subversion Repositories FlightCtrl

Rev

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

Rev 1645 Rev 1775
Line 109... Line 109...
109
#define SPIF   SPIF0
109
#define SPIF   SPIF0
110
#endif
110
#endif
111
#ifndef WCOL
111
#ifndef WCOL
112
#define WCOL   WCOL0
112
#define WCOL   WCOL0
113
#endif
113
#endif
114
//#ifndef SPI2X
114
#ifndef SPI2X
115
#define SPI2X  SPI2X0
115
#define SPI2X  SPI2X0
116
//#endif
116
#endif
117
// -------------------------
117
// -------------------------
Line 118... Line 118...
118
 
118
 
119
#define SLAVE_SELECT_DDR_PORT   DDRC
119
#define SLAVE_SELECT_DDR_PORT   DDRC
120
#define SLAVE_SELECT_PORT       PORTC
120
#define SLAVE_SELECT_PORT       PORTC
Line 123... Line 123...
123
#define SPI_TXSYNCBYTE1 0xAA
123
#define SPI_TXSYNCBYTE1 0xAA
124
#define SPI_TXSYNCBYTE2 0x83
124
#define SPI_TXSYNCBYTE2 0x83
125
#define SPI_RXSYNCBYTE1 0x81
125
#define SPI_RXSYNCBYTE1 0x81
126
#define SPI_RXSYNCBYTE2 0x55
126
#define SPI_RXSYNCBYTE2 0x55
Line 127... Line 127...
127
 
127
 
128
typedef enum
-
 
129
  {
128
typedef enum {
130
    SPI_SYNC1,
129
  SPI_SYNC1,
131
    SPI_SYNC2,
130
  SPI_SYNC2,
132
    SPI_DATA
131
  SPI_DATA
133
  } SPI_RXState_t;
-
 
Line 134... Line 132...
134
 
132
} SPI_RXState_t;
135
 
133
 
136
// data exchange packets to and From NaviCtrl
134
// data exchange packets to and From NaviCtrl
-
 
135
ToNaviCtrl_t                    toNaviCtrl;
Line 137... Line -...
137
ToNaviCtrl_t                    ToNaviCtrl;
-
 
Line 138... Line 136...
138
FromNaviCtrl_t                  FromNaviCtrl;
136
FromNaviCtrl_t                  fromNaviCtrl;
139
 
137
SPI_VersionInfo_t               SPI_VersionInfo;
140
SPI_VersionInfo_t SPI_VersionInfo;
138
 
141
 
139
 
142
// rx packet buffer
140
// rx packet buffer
Line 143... Line 141...
143
#define SPI_RXBUFFER_LEN sizeof(FromNaviCtrl)
141
#define SPI_RXBUFFER_LEN sizeof(fromNaviCtrl)
144
uint8_t SPI_RxBuffer[SPI_RXBUFFER_LEN];
142
uint8_t SPI_RxBuffer[SPI_RXBUFFER_LEN];
145
uint8_t SPI_RxBufferIndex = 0;
143
uint8_t SPI_RxBufferIndex = 0;
146
uint8_t SPI_RxBuffer_Request = 0;
144
uint8_t SPI_RxBuffer_Request = 0;
Line 147... Line 145...
147
 
145
 
148
// tx packet buffer
146
// tx packet buffer
Line 168... Line 166...
168
  SPCR = (1<<SPE)|(1<<MSTR)|(1<<SPR1)|(0<<SPR0)|(0<<SPIE);   // Enable SPI, Master, set clock rate fck/64
166
  SPCR = (1<<SPE)|(1<<MSTR)|(1<<SPR1)|(0<<SPR0)|(0<<SPIE);   // Enable SPI, Master, set clock rate fck/64
169
  SPSR = 0;//(1<<SPI2X);
167
  SPSR = 0;//(1<<SPI2X);
Line 170... Line 168...
170
 
168
 
Line 171... Line 169...
171
  SLAVE_SELECT_PORT |=  (1 << SPI_SLAVE_SELECT); // Deselect Slave
169
  SLAVE_SELECT_PORT |=  (1 << SPI_SLAVE_SELECT); // Deselect Slave
172
 
170
 
173
  SPI_TxBuffer = (uint8_t *) &ToNaviCtrl; // set pointer to tx-buffer
171
  SPI_TxBuffer = (uint8_t *) &toNaviCtrl; // set pointer to tx-buffer
174
  SPITransferCompleted = 1;
172
  SPITransferCompleted = 1;
175
  // initialize data packet to NaviControl
173
  // initialize data packet to NaviControl
Line 176... Line 174...
176
  ToNaviCtrl.Sync1 = SPI_TXSYNCBYTE1;
174
  toNaviCtrl.Sync1 = SPI_TXSYNCBYTE1;
177
  ToNaviCtrl.Sync2 = SPI_TXSYNCBYTE2;
175
  toNaviCtrl.Sync2 = SPI_TXSYNCBYTE2;
178
 
176
 
179
  ToNaviCtrl.Command = SPI_CMD_USER;
177
  toNaviCtrl.Command = SPI_CMD_USER;
180
  ToNaviCtrl.IntegralNick = 0;
178
  toNaviCtrl.IntegralPitch = 0;
Line 181... Line 179...
181
  ToNaviCtrl.IntegralRoll = 0;
179
  toNaviCtrl.IntegralRoll = 0;
Line 188... Line 186...
188
  SPI_VersionInfo.Minor = VERSION_MINOR;
186
  SPI_VersionInfo.Minor = VERSION_MINOR;
189
  SPI_VersionInfo.Patch = VERSION_PATCH;
187
  SPI_VersionInfo.Patch = VERSION_PATCH;
190
  SPI_VersionInfo.Compatible = NC_SPI_COMPATIBLE;
188
  SPI_VersionInfo.Compatible = NC_SPI_COMPATIBLE;
191
}
189
}
Line 192... Line -...
192
 
-
 
193
 
190
 
194
/**********************************************************/
191
/**********************************************************/
195
/*  Update Data transferd by the SPI from/to NaviCtrl     */
192
/*  Update Data transferd by the SPI from/to NaviCtrl     */
196
/**********************************************************/
193
/**********************************************************/
197
void UpdateSPI_Buffer(void) {
194
void UpdateSPI_Buffer(void) {
198
  uint8_t i;
195
  uint8_t i;
199
  int16_t tmp;
196
  int16_t tmp;
Line 200... Line 197...
200
  cli(); // stop all interrupts to avoid writing of new data during update of that packet.
197
  cli(); // stop all interrupts to avoid writing of new data during update of that packet.
201
 
198
 
202
  // update content of packet to NaviCtrl
199
  // update content of packet to NaviCtrl
203
  ToNaviCtrl.IntegralNick = (int16_t)((10 * angle[PITCH]) / GYRO_DEG_FACTOR_PITCHROLL); // convert to multiple of 0.1°
200
  toNaviCtrl.IntegralPitch = (int16_t)((10 * angle[PITCH]) / GYRO_DEG_FACTOR_PITCHROLL); // convert to multiple of 0.1°
204
  ToNaviCtrl.IntegralRoll = (int16_t)((10 * angle[ROLL]) / GYRO_DEG_FACTOR_PITCHROLL); // convert to multiple of 0.1°
201
  toNaviCtrl.IntegralRoll  = (int16_t)((10 * angle[ROLL]) / GYRO_DEG_FACTOR_PITCHROLL);  // convert to multiple of 0.1°
205
  ToNaviCtrl.GyroHeading  = (int16_t)((10 * yawGyroHeading)   / GYRO_DEG_FACTOR_YAW); // convert to multiple of 0.1°
202
  toNaviCtrl.GyroHeading   = (int16_t)((10 * yawGyroHeading)   / GYRO_DEG_FACTOR_YAW);   // convert to multiple of 0.1°
206
  ToNaviCtrl.GyroNick = rate_PID[PITCH]; // TODO: Which one should it be??
203
  toNaviCtrl.GyroPitch = rate_ATT[PITCH];
207
  ToNaviCtrl.GyroRoll = rate_PID[ROLL];
204
  toNaviCtrl.GyroRoll = rate_ATT[ROLL];
208
  ToNaviCtrl.GyroYaw =  yawRate;
205
  toNaviCtrl.GyroYaw  = yawRate;
209
  ToNaviCtrl.AccNick =  0; // ((int16_t) 10 * ACC_AMPLIFY * (NaviAccNick / NaviCntAcc)) / ACC_DEG_FACTOR; // convert to multiple of 0.1°
-
 
Line -... Line 206...
-
 
206
  toNaviCtrl.AccPitch = (10 * getAngleEstimateFromAcc(PITCH)) / GYRO_DEG_FACTOR_PITCHROLL; // convert to multiple of 0.1°
-
 
207
  toNaviCtrl.AccRoll  = (10 * getAngleEstimateFromAcc(ROLL))  / GYRO_DEG_FACTOR_PITCHROLL; // convert to multiple of 0.1°
-
 
208
 
-
 
209
 
-
 
210
  // TODO: What are these little bastards?
210
  ToNaviCtrl.AccRoll =  0; // ((int16_t) 10 * ACC_AMPLIFY * (NaviAccRoll / NaviCntAcc)) / ACC_DEG_FACTOR; // convert to multiple of 0.1°
211
 
211
  // naviCntAcc = 0; naviAccPitch = 0; naviAccRoll = 0;
212
  averageAcc[PITCH] = averageAcc[ROLL] = averageAccCount = 0;
212
 
213
 
213
  switch(ToNaviCtrl.Command) {
214
  switch(toNaviCtrl.Command) {
214
  case SPI_CMD_USER:
215
  case SPI_CMD_USER:
215
    for (i=0; i<sizeof(dynamicParams.UserParams); i++) {
216
    for (i=0; i<sizeof(dynamicParams.UserParams); i++) {
216
      ToNaviCtrl.Param.Byte[i] = dynamicParams.UserParams[i];
217
      toNaviCtrl.Param.Byte[i] = dynamicParams.UserParams[i];
217
    }
218
    }
218
    ToNaviCtrl.Param.Byte[8] = MKFlags;
219
    toNaviCtrl.Param.Byte[8] = MKFlags;
219
    MKFlags &= ~(MKFLAG_CALIBRATE | MKFLAG_START); // calibrate and start are temporal states that are cleared immediately after transmitting
220
    MKFlags &= ~(MKFLAG_CALIBRATE | MKFLAG_START); // calibrate and start are temporal states that are cleared immediately after transmitting
220
    ToNaviCtrl.Param.Byte[9] = (uint8_t)UBat;
221
    toNaviCtrl.Param.Byte[9] = (uint8_t)UBat;
Line 221... Line 222...
221
    ToNaviCtrl.Param.Byte[10] = staticParams.LowVoltageWarning;
222
    toNaviCtrl.Param.Byte[10] = staticParams.LowVoltageWarning;
222
    ToNaviCtrl.Param.Byte[11] = getActiveParamSet();
223
    toNaviCtrl.Param.Byte[11] = getActiveParamSet();
223
    break;
224
    break;
224
 
225
 
225
  case SPI_CMD_PARAMETER1:
226
  case SPI_CMD_PARAMETER1:
226
    ToNaviCtrl.Param.Byte[0] = staticParams.NaviGpsModeControl;     // Parameters for the Naviboard
227
    toNaviCtrl.Param.Byte[0] = staticParams.NaviGpsModeControl;     // Parameters for the Naviboard
227
    ToNaviCtrl.Param.Byte[1] = staticParams.NaviGpsGain;
228
    toNaviCtrl.Param.Byte[1] = staticParams.NaviGpsGain;
228
    ToNaviCtrl.Param.Byte[2] = staticParams.NaviGpsP;
229
    toNaviCtrl.Param.Byte[2] = staticParams.NaviGpsP;
229
    ToNaviCtrl.Param.Byte[3] = staticParams.NaviGpsI;
230
    toNaviCtrl.Param.Byte[3] = staticParams.NaviGpsI;
230
    ToNaviCtrl.Param.Byte[4] = staticParams.NaviGpsD;
231
    toNaviCtrl.Param.Byte[4] = staticParams.NaviGpsD;
231
    ToNaviCtrl.Param.Byte[5] = staticParams.NaviGpsACC;
232
    toNaviCtrl.Param.Byte[5] = staticParams.NaviGpsACC;
232
    ToNaviCtrl.Param.Byte[6] = staticParams.NaviGpsMinSat;
233
    toNaviCtrl.Param.Byte[6] = staticParams.NaviGpsMinSat;
233
    ToNaviCtrl.Param.Byte[7] = staticParams.NaviStickThreshold;
234
    toNaviCtrl.Param.Byte[7] = staticParams.NaviStickThreshold;
234
    ToNaviCtrl.Param.Byte[8] = staticParams.NaviOperatingRadius;
235
    toNaviCtrl.Param.Byte[8] = staticParams.NaviOperatingRadius;
Line 235... Line 236...
235
    ToNaviCtrl.Param.Byte[9] = staticParams.NaviWindCorrection;
236
    toNaviCtrl.Param.Byte[9] = staticParams.NaviWindCorrection;
236
    ToNaviCtrl.Param.Byte[10] = staticParams.NaviSpeedCompensation;
237
    toNaviCtrl.Param.Byte[10] = staticParams.NaviSpeedCompensation;
237
    ToNaviCtrl.Param.Byte[11] = staticParams.NaviAngleLimitation;
238
    toNaviCtrl.Param.Byte[11] = staticParams.NaviAngleLimitation;
238
    break;
239
    break;
239
   
240
   
240
  case SPI_CMD_STICK:
241
  case SPI_CMD_STICK:
241
    tmp = PPM_in[staticParams.ChannelAssignment[CH_THROTTLE]];  if(tmp > 127) tmp = 127; else if(tmp < -128) tmp = -128;
242
    tmp = PPM_in[staticParams.ChannelAssignment[CH_THROTTLE]];  if(tmp > 127) tmp = 127; else if(tmp < -128) tmp = -128;
242
    ToNaviCtrl.Param.Byte[0] = (int8_t) tmp;
243
    toNaviCtrl.Param.Byte[0] = (int8_t) tmp;
243
    tmp = PPM_in[staticParams.ChannelAssignment[CH_YAW]]; if(tmp > 127) tmp = 127; else if(tmp < -128) tmp = -128;
244
    tmp = PPM_in[staticParams.ChannelAssignment[CH_YAW]]; if(tmp > 127) tmp = 127; else if(tmp < -128) tmp = -128;
244
    ToNaviCtrl.Param.Byte[1] = (int8_t) tmp;
245
    toNaviCtrl.Param.Byte[1] = (int8_t) tmp;
245
    tmp = PPM_in[staticParams.ChannelAssignment[CH_ROLL]]; if(tmp > 127) tmp = 127; else if(tmp < -128) tmp = -128;
246
    tmp = PPM_in[staticParams.ChannelAssignment[CH_ROLL]]; if(tmp > 127) tmp = 127; else if(tmp < -128) tmp = -128;
246
    ToNaviCtrl.Param.Byte[2] = (int8_t) tmp;
247
    toNaviCtrl.Param.Byte[2] = (int8_t) tmp;
247
    tmp = PPM_in[staticParams.ChannelAssignment[CH_PITCH]]; if(tmp > 127) tmp = 127; else if(tmp < -128) tmp = -128;
248
    tmp = PPM_in[staticParams.ChannelAssignment[CH_PITCH]]; if(tmp > 127) tmp = 127; else if(tmp < -128) tmp = -128;
248
    ToNaviCtrl.Param.Byte[3] = (int8_t) tmp;
249
    toNaviCtrl.Param.Byte[3] = (int8_t) tmp;
249
    ToNaviCtrl.Param.Byte[4] = (uint8_t) variables[0];
250
    toNaviCtrl.Param.Byte[4] = (uint8_t) variables[0];
Line 250... Line 251...
250
    ToNaviCtrl.Param.Byte[5] = (uint8_t) variables[1];
251
    toNaviCtrl.Param.Byte[5] = (uint8_t) variables[1];
251
    ToNaviCtrl.Param.Byte[6] = (uint8_t) variables[2];
252
    toNaviCtrl.Param.Byte[6] = (uint8_t) variables[2];
252
    ToNaviCtrl.Param.Byte[7] = (uint8_t) variables[3];
253
    toNaviCtrl.Param.Byte[7] = (uint8_t) variables[3];
253
    ToNaviCtrl.Param.Byte[8] = (uint8_t) RC_Quality;
-
 
254
    break;
254
    toNaviCtrl.Param.Byte[8] = (uint8_t) RC_Quality;
255
 
255
    break;
256
  case SPI_CMD_MISC:
256
 
-
 
257
  case SPI_CMD_MISC:
257
    ToNaviCtrl.Param.Byte[0] = compassCalState;
258
    toNaviCtrl.Param.Byte[0] = compassCalState;
258
    if(compassCalState > 4)
259
    if(compassCalState > 4) { // jump from 5 to 0
259
      { // jump from 5 to 0
260
          compassCalState  = 0;
260
        compassCalState  = 0;
261
    }
261
      }
262
    toNaviCtrl.Param.Byte[1] = staticParams.NaviPHLoginTime;
Line 262... Line 263...
262
    ToNaviCtrl.Param.Byte[1] = staticParams.NaviPHLoginTime;
263
    // TODO: Height and in the correct scaling...
263
    ToNaviCtrl.Param.Int[1]  = 0; //readingHeight; // at address of Byte 2 and 3
264
    toNaviCtrl.Param.Int[1]  = 0; //readingHeight; // at address of Byte 2 and 3
264
    ToNaviCtrl.Param.Byte[4] = staticParams.NaviGpsPLimit;
265
    toNaviCtrl.Param.Byte[4] = staticParams.NaviGpsPLimit;
265
    ToNaviCtrl.Param.Byte[5] = staticParams.NaviGpsILimit;
266
    toNaviCtrl.Param.Byte[5] = staticParams.NaviGpsILimit;
266
    ToNaviCtrl.Param.Byte[6] = staticParams.NaviGpsDLimit;
267
    toNaviCtrl.Param.Byte[6] = staticParams.NaviGpsDLimit;
267
    break;
268
    break;
268
   
269
   
269
  case SPI_CMD_VERSION:
-
 
270
    ToNaviCtrl.Param.Byte[0] = SPI_VersionInfo.Major;
270
  case SPI_CMD_VERSION:
271
    ToNaviCtrl.Param.Byte[1] = SPI_VersionInfo.Minor;
271
    toNaviCtrl.Param.Byte[0] = SPI_VersionInfo.Major;
272
    ToNaviCtrl.Param.Byte[2] = SPI_VersionInfo.Patch;
272
    toNaviCtrl.Param.Byte[1] = SPI_VersionInfo.Minor;
Line 273... Line 273...
273
    ToNaviCtrl.Param.Byte[3] = SPI_VersionInfo.Compatible;
273
    toNaviCtrl.Param.Byte[2] = SPI_VersionInfo.Patch;
Line 274... Line 274...
274
    ToNaviCtrl.Param.Byte[4] = BoardRelease;
274
    toNaviCtrl.Param.Byte[3] = SPI_VersionInfo.Compatible;
275
    break;
275
    toNaviCtrl.Param.Byte[4] = BoardRelease;
276
   
276
    break;
277
  default:
277
  default:
278
    break;
278
    break;
279
  }
279
  }
280
 
280
 
281
  sei(); // enable all interrupts
281
  sei(); // enable all interrupts
282
 
282
 
283
  // analyze content of packet from NaviCtrl if valid
283
  // analyze content of packet from NaviCtrl if valid
284
  if (SPI_RxDataValid) {
284
  if (SPI_RxDataValid) {
285
    // update gps controls
285
    // update gps controls
286
    if(abs(FromNaviCtrl.GPSStickNick) < 512 && abs(FromNaviCtrl.GPSStickRoll) < 512 && (staticParams.GlobalConfig & CFG_GPS_ACTIVE)) {
286
    if(abs(fromNaviCtrl.GPSStickPitch) < 512 && abs(fromNaviCtrl.GPSStickRoll) < 512 && (staticParams.GlobalConfig & CFG_GPS_ACTIVE)) {
287
      GPSStickPitch     = FromNaviCtrl.GPSStickNick;
287
      GPSStickPitch     = fromNaviCtrl.GPSStickPitch;
288
      GPSStickRoll      = FromNaviCtrl.GPSStickRoll;
288
      GPSStickRoll      = fromNaviCtrl.GPSStickRoll;
289
      NCDataOkay = 250;
289
      NCDataOkay = 250;
Line 290... Line 290...
290
    }
290
    }
291
    // update compass readings
291
    // update compass readings
292
    if(FromNaviCtrl.CompassHeading <= 360) {
292
    if(fromNaviCtrl.CompassHeading <= 360) {
293
      compassHeading = FromNaviCtrl.CompassHeading;
293
      compassHeading = fromNaviCtrl.CompassHeading;
294
    }
294
    }
295
    if(compassHeading < 0) compassOffCourse = 0;
295
    if(compassHeading < 0) compassOffCourse = 0;
296
    else compassOffCourse = ((540 + compassHeading - compassCourse) % 360) - 180;
-
 
297
    // NaviCtrl wants to beep?
296
    else compassOffCourse = ((540 + compassHeading - compassCourse) % 360) - 180;
Line 298... Line 297...
298
    if (FromNaviCtrl.BeepTime > BeepTime && !compassCalState) BeepTime = FromNaviCtrl.BeepTime;
297
    // NaviCtrl wants to beep?
299
   
298
    if (fromNaviCtrl.BeepTime > BeepTime && !compassCalState) BeepTime = fromNaviCtrl.BeepTime;
300
    switch (FromNaviCtrl.Command) {
299
   
301
    case SPI_KALMAN:
-
 
302
      dynamicParams.KalmanK = FromNaviCtrl.Param.Byte[0];
300
    switch (fromNaviCtrl.Command) {
303
      dynamicParams.KalmanMaxFusion = FromNaviCtrl.Param.Byte[1];
-
 
304
      dynamicParams.KalmanMaxDrift = FromNaviCtrl.Param.Byte[2];
301
    case SPI_KALMAN:
305
      NCSerialDataOkay = FromNaviCtrl.Param.Byte[3];
302
      dynamicParams.KalmanK             = fromNaviCtrl.Param.Byte[0];
306
      //DebugOut.Analog[29] = NCSerialDataOkay;
303
      dynamicParams.KalmanMaxFusion = fromNaviCtrl.Param.Byte[1];
307
      break;
304
      dynamicParams.KalmanMaxDrift      = fromNaviCtrl.Param.Byte[2];
308
     
305
      NCSerialDataOkay                          = fromNaviCtrl.Param.Byte[3];
Line 326... Line 323...
326
  else // transmission was completed
323
  else // transmission was completed
327
    {
324
    {
328
      SLAVE_SELECT_PORT &=  ~(1 << SPI_SLAVE_SELECT);  // Select slave
325
      SLAVE_SELECT_PORT &=  ~(1 << SPI_SLAVE_SELECT);  // Select slave
Line 329... Line 326...
329
     
326
     
330
      // cyclic commands
327
      // cyclic commands
331
      ToNaviCtrl.Command = SPI_CommandSequence[SPI_CommandCounter++];
328
      toNaviCtrl.Command = SPI_CommandSequence[SPI_CommandCounter++];
Line 332... Line 329...
332
      if (SPI_CommandCounter >= sizeof(SPI_CommandSequence)) SPI_CommandCounter = 0;
329
      if (SPI_CommandCounter >= sizeof(SPI_CommandSequence)) SPI_CommandCounter = 0;
333
     
330
     
Line 334... Line 331...
334
      SPITransferCompleted = 0; // transfer is in progress
331
      SPITransferCompleted = 0; // transfer is in progress
Line 335... Line 332...
335
      UpdateSPI_Buffer();    // update data in ToNaviCtrl
332
      UpdateSPI_Buffer();    // update data in toNaviCtrl
336
     
333
     
337
      SPI_TxBufferIndex = 1; //proceed with 2nd byte
334
      SPI_TxBufferIndex = 1; //proceed with 2nd byte
338
     
335
     
339
      // -- Debug-Output ---
336
      // -- Debug-Output ---
340
      //----
337
      //----
341
      asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");      asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
338
      asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");      asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
342
      asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");      asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
339
      asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");      asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
343
      asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");      asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
340
      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 344... Line 341...
344
      ToNaviCtrl.Chksum = ToNaviCtrl.Sync1; // init checksum
341
      toNaviCtrl.Chksum = toNaviCtrl.Sync1; // init checksum
345
      SPDR = ToNaviCtrl.Sync1; // send first byte
342
      SPDR = toNaviCtrl.Sync1; // send first byte
Line 387... Line 384...
387
    break;
384
    break;
Line 388... Line 385...
388
   
385
   
389
  case SPI_DATA: // data bytes
386
  case SPI_DATA: // data bytes
390
    SPI_RxBuffer[SPI_RxBufferIndex++] = rxdata;  // copy data byte to spi buffer
387
    SPI_RxBuffer[SPI_RxBufferIndex++] = rxdata;  // copy data byte to spi buffer
391
    // if all bytes are received of a packet from the NaviCtrl
-
 
392
    if (SPI_RxBufferIndex >= SPI_RXBUFFER_LEN)
388
    // if all bytes are received of a packet from the NaviCtrl
393
      {   // last byte transfered is the checksum of the packet
389
    if (SPI_RxBufferIndex >= SPI_RXBUFFER_LEN) {   // last byte transfered is the checksum of the packet
394
        if (rxdata == rxchksum) // checksum matching?
-
 
395
          {
390
        if (rxdata == rxchksum) { // checksum matching?
396
            // copy SPI_RxBuffer -> FromFlightCtrl
391
            // copy SPI_RxBuffer -> FromFlightCtrl
397
            uint8_t *ptr = (uint8_t *)&FromNaviCtrl;
392
            uint8_t *ptr = (uint8_t *)&fromNaviCtrl;
398
            cli();
393
            cli();
399
            memcpy(ptr, (uint8_t *) SPI_RxBuffer, sizeof(FromNaviCtrl));
394
            memcpy(ptr, (uint8_t *) SPI_RxBuffer, sizeof(fromNaviCtrl));
400
            sei();
395
            sei();
401
            SPI_RxDataValid = 1;
-
 
402
            //DebugOut.Analog[18]++;
-
 
403
          }
-
 
404
        else
396
            SPI_RxDataValid = 1;
405
          {   // checksum does not match
-
 
406
            //DebugOut.Analog[17]++;
397
          } else {   // checksum does not match
407
            SPI_RxDataValid = 0; // reset valid flag
398
            SPI_RxDataValid = 0; // reset valid flag
408
          }
399
          }
409
        SPI_RXState  = SPI_SYNC1; // reset state sync
-
 
410
      }
400
          SPI_RXState  = SPI_SYNC1; // reset state sync
411
    else // not all bytes transfered
-
 
412
      {
401
    } else { // not all bytes transfered
413
        rxchksum += rxdata; // update checksum
402
          rxchksum += rxdata; // update checksum
414
      }
403
    }
415
    break;
404
    break;
Line 416... Line 405...
416
  }// eof switch(SPI_RXState)
405
  }// eof switch(SPI_RXState)
417
 
406
 
418
  // if still some bytes left for transmission to NaviCtrl
-
 
419
  if (SPI_TxBufferIndex < SPI_TXBUFFER_LEN)
407
  // if still some bytes left for transmission to NaviCtrl
420
    {
408
  if (SPI_TxBufferIndex < SPI_TXBUFFER_LEN) {
421
      SLAVE_SELECT_PORT &=  ~(1 << SPI_SLAVE_SELECT);  // SelectSlave
409
      SLAVE_SELECT_PORT &=  ~(1 << SPI_SLAVE_SELECT);  // SelectSlave
422
      asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
410
      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 423... Line 411...
423
      asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
411
      asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
424
      asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");   asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
412
      asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");   asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop"); asm volatile ("nop");
425
     
413
     
426
      SPDR = SPI_TxBuffer[SPI_TxBufferIndex]; // transmit byte
414
      SPDR = SPI_TxBuffer[SPI_TxBufferIndex]; // transmit byte
427
      ToNaviCtrl.Chksum += SPI_TxBuffer[SPI_TxBufferIndex]; // update checksum for everey byte that was sent
415
      toNaviCtrl.Chksum += SPI_TxBuffer[SPI_TxBufferIndex]; // update checksum for everey byte that was sent
428
      SPI_TxBufferIndex++;
416
      SPI_TxBufferIndex++;
429
    } else {
417
    } else {