PX4 Firmware
PX4 Autopilot Software http://px4.io
airspeed.h
Go to the documentation of this file.
1 /****************************************************************************
2  *
3  * Copyright (c) 2013, 2014 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 #pragma once
35 
36 #include <string.h>
37 #include <drivers/device/i2c.h>
38 #include <drivers/drv_airspeed.h>
39 #include <drivers/drv_hrt.h>
40 #include <px4_platform_common/px4_config.h>
41 #include <px4_platform_common/defines.h>
42 #include <perf/perf_counter.h>
44 #include <uORB/uORB.h>
45 #include <px4_platform_common/px4_work_queue/ScheduledWorkItem.hpp>
46 
47 /* Default I2C bus */
48 static constexpr uint8_t PX4_I2C_BUS_DEFAULT = PX4_I2C_BUS_EXPANSION;
49 
50 class __EXPORT Airspeed : public device::I2C, public px4::ScheduledWorkItem
51 {
52 public:
53  Airspeed(int bus, int address, unsigned conversion_interval, const char *path);
54  virtual ~Airspeed();
55 
56  virtual int init();
57 
58  virtual int ioctl(device::file_t *filp, int cmd, unsigned long arg);
59 
60 private:
61  /* this class has pointer data members and should not be copied */
62  Airspeed(const Airspeed &);
63  Airspeed &operator=(const Airspeed &);
64 
65 protected:
66  virtual int probe();
67 
68  /**
69  * Perform a poll cycle; collect from the previous measurement
70  * and start a new one.
71  */
72  virtual void Run() = 0;
73  virtual int measure() = 0;
74  virtual int collect() = 0;
75 
76  bool _sensor_ok;
80 
83 
85 
87 
90 
91  /**
92  * Initialise the automatic measurement state machine and start it.
93  *
94  * @note This function is called at open and error time. It might make sense
95  * to make it more aggressive about resetting the bus in case of errors.
96  */
97  void start();
98 
99  /**
100  * Stop the automatic measurement state machine.
101  */
102  void stop();
103 
104  /**
105  * add a new report to the reports queue
106  *
107  * @param report differential_pressure_s report
108  */
109  void new_report(const differential_pressure_s &report);
110 };
111 
112 
orb_advert_t _airspeed_pub
Definition: airspeed.h:81
API for the uORB lightweight object broker.
unsigned _conversion_interval
Definition: airspeed.h:86
Definition: I2C.hpp:51
static void stop()
Definition: dataman.cpp:1491
int _airspeed_orb_class_instance
Definition: airspeed.h:82
High-resolution timer with callouts and timekeeping.
static constexpr uint8_t PX4_I2C_BUS_DEFAULT
Definition: airspeed.h:48
Header common to all counters.
void init()
Activates/configures the hardware registers.
perf_counter_t _sample_perf
Definition: airspeed.h:88
__BEGIN_DECLS typedef void * orb_advert_t
ORB topic advertiser handle.
Definition: uORB.h:134
int _measure_interval
Definition: airspeed.h:77
static int start()
Definition: dataman.cpp:1452
float _diff_pres_offset
Definition: airspeed.h:79
bool _collect_phase
Definition: airspeed.h:78
Airspeed driver interface.
bool _sensor_ok
Definition: airspeed.h:76
perf_counter_t _comms_errors
Definition: airspeed.h:89
int _class_instance
Definition: airspeed.h:84
Performance measuring tools.
Base class for devices connected via I2C.