PX4 Firmware
PX4 Autopilot Software http://px4.io
rm3100_main.h
Go to the documentation of this file.
1 /****************************************************************************
2  *
3  * Copyright (c) 2015 PX4 Development Team. All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  *
9  * 1. Redistributions of source code must retain the above copyright
10  * notice, this list of conditions and the following disclaimer.
11  * 2. Redistributions in binary form must reproduce the above copyright
12  * notice, this list of conditions and the following disclaimer in
13  * the documentation and/or other materials provided with the
14  * distribution.
15  * 3. Neither the name PX4 nor the names of its contributors may be
16  * used to endorse or promote products derived from this software
17  * without specific prior written permission.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
22  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
23  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
24  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
25  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
26  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
27  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
29  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30  * POSSIBILITY OF SUCH DAMAGE.
31  *
32  ****************************************************************************/
33 
34 /**
35  * @file rm3100_main.h
36  */
37 
38 #pragma once
39 
40 #include "rm3100.h"
41 
42 namespace rm3100
43 {
44 /**
45  * @struct List of supported bus configurations
46  */
49  const char *devpath;
51  uint8_t busnum;
53 } bus_options[] = {
54 #ifdef PX4_I2C_BUS_EXPANSION
55  { RM3100_BUS_I2C_EXTERNAL, "/dev/rm3100_ext", &RM3100_I2C_interface, PX4_I2C_BUS_EXPANSION, NULL },
56 #endif /* PX4_I2C_BUS_EXPANSION */
57 #ifdef PX4_I2C_BUS_EXPANSION1
58  { RM3100_BUS_I2C_EXTERNAL, "/dev/rm3100_ext1", &RM3100_I2C_interface, PX4_I2C_BUS_EXPANSION1, NULL },
59 #endif /* PX4_I2C_BUS_EXPANSION1 */
60 #ifdef PX4_I2C_BUS_EXPANSION2
61  { RM3100_BUS_I2C_EXTERNAL, "/dev/rm3100_ext2", &RM3100_I2C_interface, PX4_I2C_BUS_EXPANSION2, NULL },
62 #endif /* PX4_I2C_BUS_EXPANSION2 */
63 #ifdef PX4_I2C_BUS_ONBOARD
64  { RM3100_BUS_I2C_INTERNAL, "/dev/rm3100_int", &RM3100_I2C_interface, PX4_I2C_BUS_ONBOARD, NULL },
65 #endif /* PX4_I2C_BUS_ONBOARD */
66 #ifdef PX4_SPIDEV_RM
67  { RM3100_BUS_SPI_INTERNAL, "/dev/rm3100_spi_int", &RM3100_SPI_interface, PX4_SPI_BUS_SENSORS, NULL },
68 #endif /* PX4_SPIDEV_RM */
69 #ifdef PX4_SPIDEV_RM_EXT
70  { RM3100_BUS_SPI_EXTERNAL, "/dev/rm3100_spi_ext", &RM3100_SPI_interface, PX4_SPI_BUS_EXT, NULL },
71 #endif /* PX4_SPIDEV_RM_EXT */
72 };
73 
74 /**
75  * @brief Finds a bus structure for a bus_id
76  */
78 
79 /**
80  * @brief Prints info about the driver.
81  */
82 int info(RM3100_BUS bus_id);
83 
84 /**
85  * @brief Initializes the driver -- sets defaults and starts a cycle
86  */
87 bool init(RM3100_BUS bus_id);
88 
89 /**
90  * @brief Resets the driver.
91  */
92 bool reset(RM3100_BUS bus_id);
93 
94 /**
95  * @brief Starts the driver for a specific bus option
96  */
97 bool start_bus(struct rm3100_bus_option &bus, Rotation rotation);
98 
99 /**
100  * @brief Starts the driver. This function call only returns once the driver
101  * is either successfully up and running or failed to start.
102  */
103 int start(RM3100_BUS bus_id, Rotation rotation);
104 
105 /**
106  * @brief Stop the driver.
107  */
108 int stop();
109 
110 /**
111  * @brief Perform some basic functional tests on the driver;
112  * make sure we can collect data from the sensor in polled
113  * and automatic modes.
114  */
115 bool test(RM3100_BUS bus_id);
116 
117 /**
118  * @brief Prints info about the driver argument usage.
119  */
120 void usage();
121 
122 } // namespace RM3100
device::Device * RM3100_I2C_interface(int bus)
RM3100_BUS
Definition: rm3100.h:104
struct rm3100::rm3100_bus_option bus_options[]
bool start_bus(struct rm3100_bus_option &bus, Rotation rotation)
Starts the driver for a specific bus option.
Definition: rm3100_main.cpp:85
Definition: rm3100.h:118
device::Device *(* RM3100_constructor)(int)
Definition: rm3100.h:102
bool init(RM3100_BUS bus_id)
Initializes the driver – sets defaults and starts a cycle.
Definition: rm3100_main.cpp:59
RM3100_constructor interface_constructor
Definition: rm3100_main.h:50
int start(RM3100_BUS bus_id, Rotation rotation)
Starts the driver.
Rotation
Enum for board and external compass rotations.
Definition: rotation.h:51
void usage()
Prints info about the driver argument usage.
int info(RM3100_BUS bus_id)
Prints info about the driver.
Definition: rm3100_main.cpp:49
bool test(RM3100_BUS bus_id)
Perform some basic functional tests on the driver; make sure we can collect data from the sensor in p...
int stop()
Stop the driver.
rm3100_bus_option & find_bus(RM3100_BUS bus_id)
Finds a bus structure for a bus_id.
bool reset(RM3100_BUS bus_id)
Resets the driver.
Shared defines for the RM3100 driver.
device::Device * RM3100_SPI_interface(int bus)