mirror of git://git.sysmocom.de/ofono
gisi: Retry version query in g_isi_verify()
For some mysterious reason, not all COMMON_MESSAGEs get sent to modem. This patch adds a retry counter that tries to make sure an answer is always received.
This commit is contained in:
parent
d21c660ae2
commit
3b95fe1d10
|
@ -31,6 +31,7 @@
|
||||||
#include "client.h"
|
#include "client.h"
|
||||||
|
|
||||||
#define VERSION_TIMEOUT 5
|
#define VERSION_TIMEOUT 5
|
||||||
|
#define VERSION_RETRIES 2
|
||||||
|
|
||||||
#define COMMON_MESSAGE 0xF0
|
#define COMMON_MESSAGE 0xF0
|
||||||
#define COMM_ISI_VERSION_GET_REQ 0x12
|
#define COMM_ISI_VERSION_GET_REQ 0x12
|
||||||
|
@ -40,8 +41,22 @@
|
||||||
struct verify_data {
|
struct verify_data {
|
||||||
GIsiVerifyFunc func;
|
GIsiVerifyFunc func;
|
||||||
void *data;
|
void *data;
|
||||||
|
guint count;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static GIsiRequest *send_version_query(GIsiClient *client, GIsiResponseFunc cb,
|
||||||
|
void *opaque)
|
||||||
|
{
|
||||||
|
uint8_t msg[] = {
|
||||||
|
COMMON_MESSAGE,
|
||||||
|
COMM_ISI_VERSION_GET_REQ,
|
||||||
|
0x00 /* Filler */
|
||||||
|
};
|
||||||
|
|
||||||
|
return g_isi_request_make(client, msg, sizeof(msg), VERSION_TIMEOUT,
|
||||||
|
cb, opaque);
|
||||||
|
}
|
||||||
|
|
||||||
static gboolean verify_cb(GIsiClient *client, const void *restrict data,
|
static gboolean verify_cb(GIsiClient *client, const void *restrict data,
|
||||||
size_t len, uint16_t object, void *opaque)
|
size_t len, uint16_t object, void *opaque)
|
||||||
{
|
{
|
||||||
|
@ -51,8 +66,20 @@ static gboolean verify_cb(GIsiClient *client, const void *restrict data,
|
||||||
|
|
||||||
gboolean alive = FALSE;
|
gboolean alive = FALSE;
|
||||||
|
|
||||||
if (!msg)
|
if (!msg) {
|
||||||
|
|
||||||
|
if (++vd->count < VERSION_RETRIES) {
|
||||||
|
|
||||||
|
g_warning("Retry COMM_ISI_VERSION_GET_REQ");
|
||||||
|
|
||||||
|
if (send_version_query(client, verify_cb, opaque))
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_warning("Timeout COMM_ISI_VERSION_GET_REQ");
|
||||||
|
|
||||||
goto out;
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
if (len < 2 || msg[0] != COMMON_MESSAGE)
|
if (len < 2 || msg[0] != COMMON_MESSAGE)
|
||||||
goto out;
|
goto out;
|
||||||
|
@ -69,6 +96,7 @@ static gboolean verify_cb(GIsiClient *client, const void *restrict data,
|
||||||
out:
|
out:
|
||||||
if (func)
|
if (func)
|
||||||
func(client, alive, object, vd->data);
|
func(client, alive, object, vd->data);
|
||||||
|
|
||||||
g_free(vd);
|
g_free(vd);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
@ -87,17 +115,11 @@ GIsiRequest *g_isi_verify(GIsiClient *client, GIsiVerifyFunc func,
|
||||||
{
|
{
|
||||||
struct verify_data *data = g_try_new0(struct verify_data, 1);
|
struct verify_data *data = g_try_new0(struct verify_data, 1);
|
||||||
GIsiRequest *req = NULL;
|
GIsiRequest *req = NULL;
|
||||||
uint8_t msg[] = {
|
|
||||||
COMMON_MESSAGE,
|
|
||||||
COMM_ISI_VERSION_GET_REQ,
|
|
||||||
0x00 /* Filler */
|
|
||||||
};
|
|
||||||
|
|
||||||
data->func = func;
|
data->func = func;
|
||||||
data->data = opaque;
|
data->data = opaque;
|
||||||
|
|
||||||
req = g_isi_request_make(client, msg, sizeof(msg), VERSION_TIMEOUT,
|
req = send_version_query(client, verify_cb, data);
|
||||||
verify_cb, data);
|
|
||||||
if (!req)
|
if (!req)
|
||||||
g_free(data);
|
g_free(data);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue