[4.4.2] Remove 15 m/s limit on estimated vario (#12788)
[betaflight.git] / src / main / drivers / compass / compass_fake.c
blob59e043b7177b244642f26835d8527db810a31474
1 /*
2 * This file is part of Cleanflight and Betaflight.
4 * Cleanflight and Betaflight are free software. You can redistribute
5 * this software and/or modify this software under the terms of the
6 * GNU General Public License as published by the Free Software
7 * Foundation, either version 3 of the License, or (at your option)
8 * any later version.
10 * Cleanflight and Betaflight are distributed in the hope that they
11 * will be useful, but WITHOUT ANY WARRANTY; without even the implied
12 * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
13 * See the GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this software.
18 * If not, see <http://www.gnu.org/licenses/>.
21 #include <stdbool.h>
22 #include <stdint.h>
24 #include "platform.h"
26 #ifdef USE_FAKE_MAG
28 #include "build/build_config.h"
30 #include "common/axis.h"
31 #include "common/utils.h"
33 #include "compass.h"
34 #include "compass_fake.h"
37 static int16_t fakeMagData[XYZ_AXIS_COUNT];
39 static bool fakeMagInit(magDev_t *mag)
41 UNUSED(mag);
43 // initially point north
44 fakeMagData[X] = 4096;
45 fakeMagData[Y] = 0;
46 fakeMagData[Z] = 0;
47 return true;
50 void fakeMagSet(int16_t x, int16_t y, int16_t z)
52 fakeMagData[X] = x;
53 fakeMagData[Y] = y;
54 fakeMagData[Z] = z;
57 static bool fakeMagRead(magDev_t *mag, int16_t *magData)
59 UNUSED(mag);
61 magData[X] = fakeMagData[X];
62 magData[Y] = fakeMagData[Y];
63 magData[Z] = fakeMagData[Z];
64 return true;
67 bool fakeMagDetect(magDev_t *mag)
69 mag->init = fakeMagInit;
70 mag->read = fakeMagRead;
71 return true;
73 #endif // USE_FAKE_MAG