Rev 2160 |
Go to most recent revision |
Blame |
Compare with Previous |
Last modification |
View Log
| RSS feed
#ifndef _CONFIGURATION_H
#define _CONFIGURATION_H
#include <inttypes.h>
#include <avr/io.h>
#define MAX_CONTROLCHANNELS 8
#define MAX_I2CCHANNELS 8
#define MAX_PWMCHANNELS 8
// bitmask for VersionInfo_t.HardwareError[0]
#define FC_ERROR0_GYRO_X 0x01
#define FC_ERROR0_GYRO_Y 0x02
#define FC_ERROR0_GYRO_Z 0x04
#define FC_ERROR0_ACCEL_X 0x08
#define FC_ERROR0_ACCEL_Y 0x10
#define FC_ERROR0_ACCEL_Z 0x20
#define FC_ERROR0_PRESSURE 0x40
#define FC_ERROR1_RES0 0x80
// bitmask for VersionInfo_t.HardwareError[1]
#define FC_ERROR1_I2C 0x01
#define FC_ERROR1_BL_MISSING 0x02
#define FC_ERROR1_SPI_RX 0x04
#define FC_ERROR1_PPM 0x08
#define FC_ERROR1_MIXER 0x10
#define FC_ERROR1_RES1 0x20
#define FC_ERROR1_RES2 0x40
#define FC_ERROR1_RES3 0x80
#define PID_NORMAL_VALUE 100
typedef struct {
uint8_t SWMajor;
uint8_t SWMinor;
uint8_t SWPatch;
uint8_t protoMajor;
uint8_t protoMinor;
uint8_t hardwareErrors[5];
}__attribute__((packed)) VersionInfo_t;
extern VersionInfo_t versionInfo;
typedef struct {
uint8_t flightMode;
uint8_t attGyroP; // Attitude mode Proportional (attitude error to control)
uint8_t attGyroI; // Attitude mode Integral (attitude error integral to control. Serves to eliminate permanent attitude errors)
uint8_t attGyroD; // Attitude mode rate
uint8_t rateGyroP; // Rate mode Proportional
uint8_t rateGyroI; // Rate mode Integral (serves to eliminate slow rotation errors in rate mode)
uint8_t rateGyroD; // Rate mode Differential (GyroD)
uint8_t yawGyroP;
uint8_t yawGyroI;
uint8_t yawGyroD;
// Control
uint8_t externalControl;
uint8_t attitudeControl;
// Height control
uint8_t heightP;
uint8_t heightI;
uint8_t heightD;
uint8_t heightSetting;
// Output and servo
uint8_t output0Timing;
uint8_t output1Timing;
uint8_t servoManualControl[2];
// Correction
uint8_t levelCorrection[2];
// Simple direct navigation
uint8_t naviMode;
/* P */uint8_t userParams[8];
} DynamicParams_t;
extern volatile DynamicParams_t dynamicParams;
typedef struct {
uint8_t sourceIdx, targetIdx;
uint8_t min, max;
} MMXLATION;
/*
typedef struct {
uint8_t sourceIdx, targetIdx;
} XLATION;
*/
typedef struct {
uint8_t RCPolarity; // 1=positive, 0=negative. Use positive with Futaba receiver, negative with FrSky.
uint8_t HWTrim;
uint8_t variableOffset;
uint8_t channels[MAX_CONTROLCHANNELS];
} ChannelMap_t;
extern ChannelMap_t channelMap;
#define LOG_MOTOR_MIXER_UNIT 6
#define LOG_DYNAMIC_STABILITY_SCALER 6
typedef enum {
MIXER_SOURCE_ROLL = 0,
MIXER_SOURCE_PITCH = 1,
MIXER_SOURCE_THROTTLE = 2,
MIXER_SOURCE_YAW = 3
} MixerSource_Control;
typedef enum {
MIXER_SOURCE_AUX_GIMBAL_ROLL = 0,
MIXER_SOURCE_AUX_GIMBAL_PITCH = 1,
MIXER_SOURCE_AUX_RCCHANNEL = 2,
MIXER_SOURCE_AUX_END = 2 + MAX_CONTROLCHANNELS
} MixerSourceAux;
typedef enum {
I2C0 = 0,
I2C1 = 1,
I2C2 = 2,
I2C3 = 3,
I2C4 = 4,
I2C5 = 5,
I2C6 = 6,
I2C7 = 7,
SERVO0 = MAX_I2CCHANNELS,
NUM_OUTPUTS = 8 + MAX_PWMCHANNELS
} MixerDestination;
typedef struct {
uint8_t outputType;
uint8_t minValue;
uint8_t maxValue;
int8_t flightControls[4];
uint8_t auxSource; // for selecting a gimbal axis or an RC channel.
uint8_t oppositeMotor; // only relevant where used to control a multicopter motor.
}__attribute__((packed)) MixerMatrixRow_t;
typedef MixerMatrixRow_t OutputMixer_t[NUM_OUTPUTS];
extern OutputMixer_t outputMixer;
typedef enum {
OUTPUT_TYPE_UNDEFINED,
OUTPUT_TYPE_MOTOR,
OUTPUT_TYPE_SERVO
} outputTypes;
typedef struct {
int16_t offsets[3];
} sensorOffset_t;
typedef struct {
uint8_t manualControl;
uint8_t stabilizationFactor;
uint8_t flags;
} Servo_t;
#define SERVO_STABILIZATION_REVERSE 1
typedef struct {
uint8_t bitmask;
uint8_t timing;
} output_flash_t;
typedef struct {
/* Set up so that
* Nose-up is positive on pitch
* Roll-right is positive on roll
* Turn-ccw is positive on yaw
*/
uint8_t gyroQuadrant;
/*
* Set up so that:
* Acc. Z is +1g in normal attitude
* Acc. X gets positive in a left roll
* Acc. Y gets positive in a nose-up attitude.
*/
uint8_t accQuadrant;
uint8_t imuReversedFlags;
uint8_t gyroPIDFilterConstant;
uint8_t gyroDWindowLength;
uint8_t accFilterConstant;
} IMUConfig_t;
extern IMUConfig_t IMUConfig;
// values above 250 representing poti1 to poti4
typedef struct {
// Global bitflags
uint8_t bitConfig; // see upper defines for bitcoding
uint8_t flightMode;
// uint8_t axisCoupling1; // Value: 0-250 Faktor, mit dem Yaw die Achsen Roll und Nick koppelt (NickRollMitkopplung)
// uint8_t axisCoupling2; // Value: 0-250 Faktor, mit dem Nick und Roll verkoppelt werden
// uint8_t axisCouplingYawCorrection;// Value: 0-250 Faktor, mit dem Nick und Roll verkoppelt werden
uint8_t levelCorrection[2];
// Control
uint8_t attGyroP; // Attitude mode Proportional (attitude error to control)
uint8_t attGyroI; // Attitude mode Integral (attitude error integral to control. Serves to eliminate permanent attitude errors)
uint8_t attGyroIMax; // Attitude mode Integral max. limit
uint8_t attGyroD; // Attitude mode rate
uint8_t rateGyroP; // Rate mode Proportional
uint8_t rateGyroI; // Rate mode Integral (serves to eliminate slow rotation errors in rate mode)
uint8_t rateGyroIMax; // Rate mode Integral max. limit
uint8_t rateGyroD; // Rate mode Differential (GyroD)
uint8_t yawGyroP;
uint8_t yawGyroI;
uint8_t yawGyroD;
uint8_t externalControl; // for serial Control
uint8_t attitudeControl;
uint8_t dynamicStability;
uint8_t stickP;
uint8_t stickD;
uint8_t stickYawP;
uint8_t stickThrottleD;
// Idle throttle. Affects the throttle stick only.
uint8_t minThrottle;
// Value of max. throttle stick.
uint8_t maxThrottle;
uint8_t compassMode; // bitflag thing.
uint8_t compassYawCorrection;
uint8_t compassBendingReturnSpeed;
uint8_t compassP;
uint8_t batteryVoltageWarning;
uint8_t emergencyThrottle;
uint8_t emergencyFlightDuration;
// Height Control
uint8_t airpressureFilterConstant;
uint8_t airpressureWindowLength; // 0 means: Use filter.
uint8_t airpressureDWindowLength; // values 1..5 are legal.
uint8_t airpressureAccZCorrection;
uint8_t heightP;
uint8_t heightI;
uint8_t heightD;
uint8_t heightSetting;
uint8_t heightControlMaxIntegralIn;
uint8_t heightControlMaxIntegralOut;
uint8_t heightControlMaxThrottleChange;
uint8_t heightControlTestOscPeriod;
uint8_t heightControlTestOscAmplitude;
// Servos
uint8_t servoCount;
uint8_t servoManualMaxSpeed;
Servo_t servoConfigurations[2]; // [PITCH, ROLL]
// Outputs
output_flash_t outputFlash[2];
uint8_t outputDebugMask;
uint8_t outputFlags;
// Shared for both modes of navigation
uint8_t naviMode;
uint8_t naviStickThreshold;
uint8_t naviStickLimit;
uint8_t GPSMininumSatellites;
uint8_t naviP;
uint8_t naviI;
uint8_t naviD;
uint8_t naviTestOscPeriod;
uint8_t naviTestOscAmplitude;
// User params
uint8_t userParams[8];
// Name
char name[12];
} ParamSet_t;
extern ParamSet_t staticParams;
// MKFlags
#define MKFLAG_MOTOR_RUN (1<<0)
//#define MKFLAG_FLY (1<<1)
//#define MKFLAG_CALIBRATE (1<<2)
#define MKFLAG_EMERGENCY_FLIGHT (1<<4)
#define MKFLAG_LOWBAT (1<<5)
//#define MKFLAG_RESERVE2 (1<<6)
//#define MKFLAG_RESERVE3 (1<<7)
// bit mask for staticParams.bitConfig
#define CFG_SIMPLE_HEIGHT_CONTROL (1<<0)
#define CFG_SIMPLE_HC_HOLD_SWITCH (1<<1)
#define CFG_UNUSED (1<<2)
#define CFG_COMPASS_ENABLED (1<<3)
#define CFG_UNUSED2 (1<<4)
#define CFG_NAVI_ENABLED (1<<5)
#define CFG_UNUSED3 (1<<6)
#define CFG_GYRO_SATURATION_PREVENTION (1<<7)
#define IMU_REVERSE_GYRO_XY (1<<0)
#define IMU_REVERSE_GYRO_Z (1<<1)
#define IMU_REVERSE_ACCEL_XY (1<<2)
#define IMU_REVERSE_ACCEL_Z (1<<3)
#define ATMEGA644 0
#define ATMEGA644P 1
// Not really a part of configuration, but LEDs and HW s test are the same.
#define RED_OFF {if((boardRelease == 10) || (boardRelease == 20)) PORTB &=~(1<<PORTB0); else PORTB |= (1<<PORTB0);}
#define RED_ON {if((boardRelease == 10) || (boardRelease == 20)) PORTB |= (1<<PORTB0); else PORTB &=~(1<<PORTB0);}
#define RED_FLASH PORTB ^= (1<<PORTB0)
#define GRN_OFF {if(boardRelease < 12) PORTB &=~(1<<PORTB1); else PORTB |= (1<<PORTB1);}
#define GRN_ON {if(boardRelease < 12) PORTB |= (1<<PORTB1); else PORTB &=~(1<<PORTB1);}
#define GRN_FLASH PORTB ^= (1<<PORTB1)
// Mixer table
#define VARIABLE_COUNT 8
extern volatile uint8_t MKFlags;
extern int16_t variables[VARIABLE_COUNT]; // The "Poti"s.
extern uint8_t boardRelease;
extern uint8_t CPUType;
extern volatile uint8_t MKFlags;
extern uint16_t isFlying;
void IMUConfig_default(void);
void channelMap_default(void);
void paramSet_default(uint8_t setnumber);
void outputMixer_default(void);
void configuration_setNormalFlightMode(void);
void configuration_setFailsafeFlightMode(void);
void configuration_applyVariablesToParams(void);
void setCPUType(void);
void setBoardRelease(void);
// Called after a change in configuration parameters, as a hook for modules to take over changes.
void configuration_paramSetDidChange(void);
#endif // _CONFIGURATION_H