mirror of
https://github.com/RobotechLille/cdf2018-principal
synced 2025-10-24 17:53:31 +02:00
Tolérance au loupage de message du FPGA
This commit is contained in:
parent
1337bd62a9
commit
63bf4ee3c3
3 changed files with 81 additions and 64 deletions
|
@ -5,6 +5,7 @@
|
|||
#include <math.h>
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
#include <time.h>
|
||||
#include <unistd.h>
|
||||
|
||||
#include "debug.h"
|
||||
|
@ -29,14 +30,20 @@ void onF2CI_CODER()
|
|||
pthread_mutex_unlock(&posPolling);
|
||||
}
|
||||
|
||||
struct timespec maxDelayDelta = { 0, 10000000 };
|
||||
|
||||
void updateDelta()
|
||||
{
|
||||
// Sending
|
||||
int ret = -1;
|
||||
pthread_mutex_lock(&posPolling);
|
||||
sendCF(F2CI_CODER, NULL, 0);
|
||||
|
||||
// Waiting for reception
|
||||
pthread_mutex_lock(&posPolling);
|
||||
while (ret != 0) {
|
||||
// Sending
|
||||
sendCF(F2CI_CODER, NULL, 0);
|
||||
// Waiting for reception
|
||||
ret = pthread_mutex_timedlock(&posPolling, &maxDelayDelta);
|
||||
}
|
||||
|
||||
pthread_mutex_unlock(&posPolling);
|
||||
}
|
||||
|
||||
|
|
|
@ -19,15 +19,22 @@ void onF2CI_CAPT()
|
|||
pthread_mutex_unlock(&secPolling);
|
||||
}
|
||||
|
||||
struct timespec maxDelaySecu = { 0, 10000000 };
|
||||
|
||||
void* TaskSecurite(void* pData)
|
||||
{
|
||||
(void)pData;
|
||||
|
||||
for (;;) {
|
||||
|
||||
int ret = -1;
|
||||
pthread_mutex_lock(&secPolling);
|
||||
sendCF(F2CI_CAPT, NULL, 0);
|
||||
// Waiting for reception
|
||||
pthread_mutex_lock(&secPolling);
|
||||
while (ret != 0) {
|
||||
// Sending
|
||||
sendCF(F2CI_CAPT, NULL, 0);
|
||||
// Waiting for reception
|
||||
ret = pthread_mutex_timedlock(&secPolling, &maxDelaySecu);
|
||||
}
|
||||
pthread_mutex_unlock(&secPolling);
|
||||
|
||||
pthread_mutex_lock(&secData);
|
||||
|
@ -54,8 +61,8 @@ void configureSecurite()
|
|||
pthread_mutex_init(&secPolling, NULL);
|
||||
pthread_mutex_init(&secData, NULL);
|
||||
registerRxHandlerCF(F2CI_CAPT, onF2CI_CAPT);
|
||||
registerDebugVar("secFront", ld, &secFront);
|
||||
registerDebugVar("secBack", ld, &secBack);
|
||||
registerDebugVar("secFront", f, &secFront);
|
||||
registerDebugVar("secBack", f, &secBack);
|
||||
pthread_create(&tSecurite, NULL, TaskSecurite, NULL);
|
||||
}
|
||||
|
||||
|
@ -63,4 +70,3 @@ void deconfigureSecurite()
|
|||
{
|
||||
pthread_cancel(tSecurite);
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue