mirror of
https://gitee.com/mirrors_PX4/PX4-Autopilot.git
synced 2026-04-14 10:07:39 +08:00
POSIX: Fixes for HRT implementation of simulated HW clock polling
There is a race condition for the accel and mag polling rates. Whichever one gets set first, the other will be uninitialized. Set the mag polling rate to 1ms if uninitilized. Signed-off-by: Mark Charlebois <charlebm@gmail.com>
This commit is contained in:
parent
acfd1ea519
commit
db5530e1b5
@ -33,22 +33,33 @@
|
||||
|
||||
#include <px4_log.h>
|
||||
#include <semaphore.h>
|
||||
#include <stdio.h>
|
||||
#include <px4_workqueue.h>
|
||||
|
||||
#pragma once
|
||||
|
||||
__BEGIN_DECLS
|
||||
|
||||
extern sem_t _hrt_work_lock;
|
||||
extern struct wqueue_s g_hrt_work;
|
||||
|
||||
void hrt_work_queue_init(void);
|
||||
int hrt_work_queue(struct work_s *work, worker_t worker, void *arg, uint32_t delay);
|
||||
int hrt_work_cancel(struct work_s *work);
|
||||
|
||||
inline void hrt_work_lock();
|
||||
inline void hrt_work_unlock();
|
||||
|
||||
inline void hrt_work_lock()
|
||||
{
|
||||
PX4_INFO("hrt_work_lock");
|
||||
//PX4_INFO("hrt_work_lock");
|
||||
sem_wait(&_hrt_work_lock);
|
||||
}
|
||||
|
||||
inline void hrt_work_unlock();
|
||||
inline void hrt_work_unlock()
|
||||
{
|
||||
PX4_INFO("hrt_work_unlock");
|
||||
//PX4_INFO("hrt_work_unlock");
|
||||
sem_post(&_hrt_work_lock);
|
||||
}
|
||||
|
||||
__END_DECLS
|
||||
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user