Project

General

Profile

Actions

Bug #48

closed

Wifiap needs some workarounds to work

Added by Emmanuel Jubera [SAFT] over 1 year ago. Updated over 1 year ago.

Status:
Resolved
Priority:
Normal
Target version:
-
Start date:
05/17/2023
Due date:
% Done:

100%

Estimated time:
Hardware platform:
Solidrun (aarch64)
OS Affects Version/s:
arz-1.0.1
OS Fix Version/s:
Labels:

Description

Two workarounds are needed in emojy-service in order for wifiap-binding to start and work perfectly.

  1. A delay of 15 seconds (sleep 15).
  2. A NetworkManager command telling it to not manage wlan0 (nmcli dev set wlan0 managed off).

When the delay is removed, wifiap-binding can't start and this error gets logged in the system journal:
afm-system-daemon[406]: ERROR: can't wait system unit afm-service-wifiap-binding--main.service for uid 1001: Resource temporarily unavailable [/builddir/build/BUILD/afb-app-manager-10.0.1/src/afm-urun.c:301]

When the NM command is removed wifiap-binding starts but the wifi AP is unstable and connection losses occur periodically.

Actions #1

Updated by Salma RAISS over 1 year ago

  • Status changed from New to In Progress
Actions #2

Updated by Salma RAISS over 1 year ago

  • % Done changed from 0 to 20
Actions #3

Updated by Valentin Geffroy over 1 year ago

With Salma, we tried to solve both SAFT's issues:

  • during the wifi-binding initialisation phase, we had the same error than SAFT: ERROR: can't wait system unit afm-service-wifiap-binding--main.service for uid 1001: Resource temporarily unavailable [/builddir/build/BUILD/afb-app-manager-12.0.3/src/binding/afm-urun.c:303,afm_urun_once] The error is due that the binding has not finished its configuration phase while another service tries to use the same ressource. Fortunaly, changing the afm-util to afb-binder solves the issue but this is not a real solution. We're thinking to add something like a flag to indicate the initialisation phase is finished.
  • Emmanuel from SAFT had an issue with the stability of the wifi when the NM command is removed. We didn't succeed to reproduce the bug even with some differents devices which use the binding during a use of one and half hour (with a phone which was connected to the WIFI access point). We can try longer but it seems that the issue concerns the SAFT's configuration...

We used the latest SolidSense Edge Gateway available at download.redpesk.bzh:
https://download.redpesk.bzh/redpesk-lts/arz-1.1/images/smack/minimal/aarch64/solidrun-edge-gateways/

[root@2a-aa-f4-2e-6e-0e ~]# uname -a
Linux 2a-aa-f4-2e-6e-0e 5.4.47-19.solidrun.edge.gateways.bsp.rparz_1.aarch64 #1 SMP PREEMPT Thu Feb 16 15:03:54 CET 2023 aarch64 aarch64 aarch64 GNU/Linux
Actions #4

Updated by Valentin Geffroy over 1 year ago

One solution which could work has been discussed with José:

  • Add the "TimeoutStartSec=infinity" in the file /usr/local/lib/systemd/system/afm-service-wifiap-binding--main.service

Because the wifi binding is blocked at start-up by the availability of resources managed by the NetworkManager. As a result, the service fails to start when the start-up delay expires.

Actions #5

Updated by Valentin Geffroy over 1 year ago

  • % Done changed from 20 to 60
Actions #6

Updated by Emmanuel Jubera [SAFT] over 1 year ago

  • Adding directive "TimeoutStartSec=infinity" in service section of file /usr/local/lib/systemd/system/afm-service-wifiap-binding--main.service doesn't change the behaviour.
  • Increasing binding startup delay from 15 to 45 seconds doesn't change the result either.
Actions #7

Updated by Valentin Geffroy over 1 year ago

  • % Done changed from 60 to 90
Actions #8

Updated by Valentin Geffroy over 1 year ago

The framework includes a hard tempo of around 10 seconds. This explains why afm-util returned an error when the service was started.

This issue has been resolved. A RPM will be send to SAFT after a validation process. Salma changed the way the wifi access point starts. Indeed, we start the wifi access point once the binding has finished its initialisation phase.

Actions #9

Updated by Sebastien Douheret [IoT.bzh] over 1 year ago

  • Assignee changed from Salma RAISS to Valentin Geffroy
Actions #10

Updated by Valentin Geffroy over 1 year ago

  • % Done changed from 90 to 100
Actions #11

Updated by Valentin Geffroy over 1 year ago

  • Status changed from In Progress to Resolved
Actions #12

Updated by Valentin Geffroy over 1 year ago

Valentin Geffroy wrote in #note-8:

The framework includes a hard tempo of around 10 seconds. This explains why afm-util returned an error when the service was started.

This issue has been resolved. A RPM will be send to SAFT after a validation process. Salma changed the way the wifi access point starts. Indeed, we start the wifi access point once the binding has finished its initialisation phase.

Update: last thing to close the task was the latency issue. SAFT warned us about the bug, there is another internal task to solve it.

Actions

Also available in: Atom PDF