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; |
- |