-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMultiWii.h
276 lines (223 loc) · 10 KB
/
MultiWii.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
/*
* MWC Mini 基于 MWC 2.3
*
*/
#ifndef MULTIWII_H_
#define MULTIWII_H_
#define VERSION 230
#define NAVI_VERSION 5 //This allow sync with GUI
#include "types.h"
#define MINCHECK 1100
#define MAXCHECK 1900
extern volatile unsigned long timer0_overflow_count;
extern const char pidnames[];
extern const char boxnames[];
extern const uint8_t boxids[];
extern uint32_t currentTime;
extern uint16_t previousTime;
extern uint16_t cycleTime;
extern uint16_t calibratingA;
extern uint16_t calibratingB;
extern uint16_t calibratingG;
extern int16_t magHold,headFreeModeHold;
extern uint8_t vbatMin;
extern uint8_t rcOptions[CHECKBOXITEMS];
extern int32_t AltHold;
extern int16_t sonarAlt;
extern int16_t BaroPID;
extern int16_t errorAltitudeI;
extern int16_t i2c_errors_count;
extern uint8_t alarmArray[16];
extern global_conf_t global_conf;
extern imu_t imu;
extern analog_t analog;
extern alt_t alt;
extern att_t att;
#ifdef LOG_PERMANENT
extern plog_t plog;
#endif
extern int16_t debug[4];
extern conf_t conf;
#if GPS
extern gps_conf_struct GPS_conf;
#endif
extern int16_t annex650_overrun_count;
extern flags_struct_t f;
extern uint16_t intPowerTrigger1;
extern int16_t gyroZero[3];
extern int16_t angle[2];
#if BARO
extern int32_t baroPressure;
extern int32_t baroTemperature; // temp in 0.01 deg
extern int32_t baroPressureSum;
#endif
extern int16_t axisPID[3];
extern int16_t motor[8];
extern int16_t servo[8];
extern int16_t failsafeEvents;
extern volatile int16_t failsafeCnt;
extern int16_t rcData[RC_CHANS];
extern int16_t rcSerial[8];
extern int16_t rcCommand[4];
extern uint8_t rcSerialCount;
extern int16_t lookupPitchRollRC[5];
extern int16_t lookupThrottleRC[11];
#if defined(POWERMETER) || ( defined(LOG_VALUES) && (LOG_VALUES >= 3) )
#define PMOTOR_SUM 8 // index into pMeter[] for sum
extern uint32_t pMeter[PMOTOR_SUM + 1]; // we use [0:7] for eight motors,one extra for sum
extern uint8_t pMeterV; // dummy to satisfy the paramStruct logic in ConfigurationLoop()
extern uint32_t pAlarm; // we scale the eeprom value from [0:255] to this value we can directly compare to the sum in pMeter[6]
extern uint16_t powerValue; // last known current
#endif
#if defined(LCD_TELEMETRY)
extern uint8_t telemetry;
extern uint8_t telemetry_auto;
#endif
#ifdef LCD_TELEMETRY_STEP
extern char telemetryStepSequence[];
extern uint8_t telemetryStepIndex;
#endif
#if defined(LOG_VALUES) || defined(LCD_TELEMETRY)
extern uint16_t cycleTimeMax; // highest ever cycle timen
extern uint16_t cycleTimeMin; // lowest ever cycle timen
extern int32_t BAROaltMax; // maximum value
extern uint16_t GPS_speedMax; // maximum speed from gps
extern uint16_t powerValueMaxMAH;
#endif
#if defined(LOG_VALUES) || defined(LCD_TELEMETRY) || defined(ARMEDTIMEWARNING) || defined(LOG_PERMANENT)
extern uint32_t armedTime;
#endif
// *************************************** begin GPS common variables and defines ******************************************************************
extern int16_t GPS_angle[2]; // the angles that must be applied for GPS correction
extern int32_t GPS_coord[2];
extern int32_t GPS_home[2];
extern int32_t GPS_hold[2];
extern int32_t GPS_prev[2];
extern int32_t GPS_poi[2]; // Coordinates of the current poi
extern int32_t GPS_directionToPoi; // direction to the actual poi (used to set heading to poi)
extern uint8_t GPS_numSat;
extern uint16_t GPS_distanceToHome; // distance to home - unit: meter
extern int16_t GPS_directionToHome; // direction to home - unit: degree
extern uint16_t GPS_altitude; // GPS altitude - unit: meter
extern uint16_t GPS_speed; // GPS speed - unit: cm/s
extern uint8_t GPS_update; // a binary toogle to distinct a GPS position update
extern uint16_t GPS_ground_course; // - unit: degree*10
extern uint8_t GPS_Present; // Checksum from Gps serial
extern uint8_t GPS_Enable;
extern uint32_t GPS_time;
#define GPS_MODE_NONE 0 //This is the mode what is selected via the remote (NONE, HOLD, RTH and NAV (NAV-> exectute mission)
#define GPS_MODE_HOLD 1
#define GPS_MODE_RTH 2
#define GPS_MODE_NAV 3
extern uint8_t GPS_mode; // contains the current selected gps flight mode
#define NAV_STATE_NONE 0
#define NAV_STATE_RTH_START 1
#define NAV_STATE_RTH_ENROUTE 2
#define NAV_STATE_HOLD_INFINIT 3
#define NAV_STATE_HOLD_TIMED 4
#define NAV_STATE_WP_ENROUTE 5
#define NAV_STATE_PROCESS_NEXT 6
#define NAV_STATE_DO_JUMP 7
#define NAV_STATE_LAND_START 8
#define NAV_STATE_LAND_IN_PROGRESS 9
#define NAV_STATE_LANDED 10
#define NAV_STATE_LAND_SETTLE 11
#define NAV_STATE_LAND_START_DESCENT 12
#define NAV_ERROR_NONE 0 //All systems clear
#define NAV_ERROR_TOOFAR 1 //Next waypoint distance is more than safety distance
#define NAV_ERROR_SPOILED_GPS 2 //GPS reception is compromised - Nav paused - copter is adrift !
#define NAV_ERROR_WP_CRC 3 //CRC error reading WP data from EEPROM - Nav stopped
#define NAV_ERROR_FINISH 4 //End flag detected, navigation finished
#define NAV_ERROR_TIMEWAIT 5 //Waiting for poshold timer
#define NAV_ERROR_INVALID_JUMP 6 //Invalid jump target detected, aborting
#define NAV_ERROR_INVALID_DATA 7 //Invalid mission step action code, aborting, copter is adrift
#define NAV_ERROR_WAIT_FOR_RTH_ALT 8 //Waiting to reach RTH Altitude
#define NAV_ERROR_GPS_FIX_LOST 9 //Gps fix lost, aborting mission
#define NAV_ERROR_DISARMED 10 //NAV engine disabled due disarm
#define NAV_ERROR_LANDING 11
extern uint8_t NAV_error;
extern uint8_t NAV_state; /// State of the nav engine
extern uint8_t GPS_saved_mission_state;
extern uint8_t prv_gps_modes; /// GPS_checkbox items packed into 1 byte for checking GPS mode changes
extern uint32_t nav_timer_stop; /// common timer used in navigation (contains the desired stop time in millis()
extern uint16_t nav_hold_time; /// time in seconds to hold position
extern uint8_t NAV_paused_at; // This contains the mission step where poshold paused the runing mission.
extern uint8_t next_step; /// The mission step which is upcoming it equals with the mission_step stored in EEPROM
#define ASCENDING 1
#define DESCENDING -1
#define REACHED_ALT 0
// The orginal altitude used as base our new altitude during nav
extern int32_t original_altitude;
//This is the target what we want to reach
extern int32_t target_altitude;
//This is the interim value which is feeded into the althold controller
extern int32_t alt_to_hold;
extern uint32_t alt_change_timer;
extern int8_t alt_change_flag;
extern uint32_t alt_change;
extern int16_t jump_times; //How many loops do we have to do (alt/100 from mission step) -10 means not used jet, -1 unlimited
extern uint8_t land_detect; //land detector variable
// ************************
// mission step structure
// ************************
#if GPS
extern mission_step_struct mission_step;
#endif
//possible action codes for a mission step
#define MISSION_WAYPOINT 1 //Set waypoint
#define MISSION_HOLD_UNLIM 2 //Poshold unlimited
#define MISSION_HOLD_TIME 3 //Hold for a predetermined time
#define MISSION_RTH 4 //Return to HOME
#define MISSION_SET_POI 5 //Set POINT of interest
#define MISSION_JUMP 6 //Jump to the given step (#times)
#define MISSION_SET_HEADING 7 //Set heading to a given orientation (parameter 1 is the waym 0-359 degree
#define MISSION_LAND 8 //Land at the given position
#define MISSION_FLAG_END 0xA5 //Flags that this is the last step
#define MISSION_FLAG_CRC_ERROR 0xFE; //Returned WP had an EEPROM CRC error
#define MISSION_FLAG_HOME 0x01; //Returned WP is the home position
#define MISSION_FLAG_HOLD 0x02; //Returned WP is the hold position
#define MISSION_FLAG_DO_LAND 0x20; //Land when reached desired point (used in RTH)
#define MISSION_FLAG_NAV_IN_PROG 0xff; //Navigation is in progress, returned wp is home
#define LAT 0
#define LON 1
extern int16_t nav[2];
// default POSHOLD control gains
#define POSHOLD_P .11
#define POSHOLD_I 0.0
#define POSHOLD_IMAX 20 // degrees
#define POSHOLD_RATE_P 2.0
#define POSHOLD_RATE_I 0.08 // Wind control
#define POSHOLD_RATE_D 0.045 // try 2 or 3 for POSHOLD_RATE 1
#define POSHOLD_RATE_IMAX 20 // degrees
// default Navigation PID gains
#define NAV_P 1.4
#define NAV_I 0.20 // Wind control
#define NAV_D 0.08 //
#define NAV_IMAX 20 // degrees
// *************************************** end GPS common variables and defines ******************************************************************
extern volatile uint8_t spekFrameFlags;
extern volatile uint32_t spekTimeLast;
extern uint8_t spekFrameDone;
#if defined(OPENLRSv2MULTI)
extern uint8_t pot_P,pot_I; // OpenLRS onboard potentiometers for P and I trim or other usages
#endif
// **********************
//Automatic ACC Offset Calibration
// **********************
#if defined(INFLIGHT_ACC_CALIBRATION)
extern uint16_t InflightcalibratingA;
extern int16_t AccInflightCalibrationArmed;
extern uint16_t AccInflightCalibrationMeasurementDone;
extern uint16_t AccInflightCalibrationSavetoEEProm;
extern uint16_t AccInflightCalibrationActive;
#endif
#if defined(ARMEDTIMEWARNING)
extern uint32_t ArmedTimeWarningMicroSeconds;
#endif
#if defined(THROTTLE_ANGLE_CORRECTION)
extern int16_t throttleAngleCorrection;
extern int8_t cosZ;
#endif
void annexCode();
void go_disarm();
#endif /* MULTIWII_H_ */