Merge branch 'beta_mavlink2' of github.com:PX4/Firmware into paul_estimator_mavlink2

This commit is contained in:
Lorenz Meier 2014-03-17 15:08:18 +01:00
commit 44bc5db0e3
2 changed files with 20 additions and 12 deletions

View File

@ -78,12 +78,15 @@ MavlinkOrbSubscription::get_data()
bool
MavlinkOrbSubscription::update(const hrt_abstime t)
{
if (_last_check != t) {
_last_check = t;
bool updated;
orb_check(_fd, &updated);
if (_last_check == t) {
/* already checked right now, return result of the check */
return _updated;
if (updated) {
} else {
_last_check = t;
orb_check(_fd, &_updated);
if (_updated) {
orb_copy(_topic, _fd, _data);
return true;
}
@ -95,6 +98,10 @@ MavlinkOrbSubscription::update(const hrt_abstime t)
bool
MavlinkOrbSubscription::is_published()
{
if (_published) {
return true;
}
bool updated;
orb_check(_fd, &updated);

View File

@ -48,7 +48,7 @@
class MavlinkOrbSubscription
{
public:
MavlinkOrbSubscription *next;
MavlinkOrbSubscription *next; /*< pointer to next subscription in list */
MavlinkOrbSubscription(const orb_id_t topic);
~MavlinkOrbSubscription();
@ -59,18 +59,19 @@ public:
* Check if the topic has been published.
*
* This call will return true if the topic was ever published.
* @param true if the topic has been published at least once.
* @return true if the topic has been published at least once.
*/
bool is_published();
void *get_data();
const orb_id_t get_topic();
private:
const orb_id_t _topic;
int _fd;
bool _published;
void *_data;
hrt_abstime _last_check;
const orb_id_t _topic; /*< topic metadata */
int _fd; /*< subscription handle */
bool _published; /*< topic was ever published */
void *_data; /*< pointer to data buffer */
hrt_abstime _last_check; /*< time of last check */
bool _updated; /*< updated on last check */
};