From 3fe3f9698a4f6fb99ff01f29c2a98378599bc28b Mon Sep 17 00:00:00 2001 From: Me7c7 Date: Sun, 29 Sep 2024 13:08:01 +0300 Subject: [PATCH] Huawei: Init chain issues for some devices fixed. Timeout increased --- .../devices/huawei/HuaweiSupportProvider.java | 8 +++- .../devices/huawei/requests/Request.java | 41 ++++++++----------- 2 files changed, 24 insertions(+), 25 deletions(-) diff --git a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/huawei/HuaweiSupportProvider.java b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/huawei/HuaweiSupportProvider.java index faa73665e..bb4b74aaf 100644 --- a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/huawei/HuaweiSupportProvider.java +++ b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/huawei/HuaweiSupportProvider.java @@ -173,7 +173,7 @@ import nodomain.freeyourgadget.gadgetbridge.util.StringUtils; public class HuaweiSupportProvider { private static final Logger LOG = LoggerFactory.getLogger(HuaweiSupportProvider.class); - private final int initTimeout = 1000; + private final int initTimeout = 2000; private HuaweiBRSupport brSupport; private HuaweiLESupport leSupport; @@ -614,7 +614,6 @@ public class HuaweiSupportProvider { initRequestQueue.add(new GetProductInformationRequest(this)); initRequestQueue.add(new SetTimeRequest(this, true)); initRequestQueue.add(batteryLevelReq); - initRequestQueue.add(new SendFitnessUserInfoRequest(this)); initRequestQueue.add(new GetSupportedServicesRequest(this)); // MUST BE LAST - it indirectly kicks off initializeDynamicServices // Queue all the requests @@ -752,6 +751,7 @@ public class HuaweiSupportProvider { initRequestQueue.add(new SendMenstrualCapabilityRequest(this)); initRequestQueue.add(new SendNotifyHeartRateCapabilityRequest(this)); initRequestQueue.add(new SendNotifyRestHeartRateCapabilityRequest(this)); + initRequestQueue.add(new SendFitnessUserInfoRequest(this)); initRequestQueue.add(new SendRunPaceConfigRequest(this)); initRequestQueue.add(new SendDeviceReportThreshold(this)); initRequestQueue.add(new SetMediumToStrengthThresholdRequest(this)); @@ -782,6 +782,10 @@ public class HuaweiSupportProvider { // Queue all the requests for (int i = 1; i < initRequestQueue.size(); i++) { initRequestQueue.get(i - 1).setupTimeoutUntilNext(initTimeout); + if(initRequestQueue.get(i - 1) instanceof SendSetUpDeviceStatusRequest) { + // NOTE: The watch is never answer to this command. To decrease init time timeout for it is 50 ms + initRequestQueue.get(i - 1).setupTimeoutUntilNext(50); + } initRequestQueue.get(i - 1).nextRequest(initRequestQueue.get(i)); } diff --git a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/huawei/requests/Request.java b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/huawei/requests/Request.java index a30fda2ea..aa14e3abd 100644 --- a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/huawei/requests/Request.java +++ b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/huawei/requests/Request.java @@ -133,6 +133,16 @@ public class Request { } } + private Runnable getTimeoutRunnable() { + return () -> { + LOG.debug("Timeout on Service {} command {}", Integer.toHexString(this.serviceId & 0xff), Integer.toHexString(this.commandId & 0xff)); + if (finalizeReq != null) + finalizeReq.timeout(this); + else + this.handleNext(); + }; + } + public Request(HuaweiSupportProvider supportProvider, nodomain.freeyourgadget.gadgetbridge.service.btbr.TransactionBuilder builder) { this.supportProvider = supportProvider; this.paramsProvider = supportProvider.getParamsProvider(); @@ -142,13 +152,7 @@ public class Request { this.isSelfQueue = true; this.handler = new Handler(Looper.getMainLooper()); - this.timeoutRunner = () -> { - LOG.debug("Timeout on Service {} command {}", this.serviceId, this.commandId); - if (finalizeReq != null) - finalizeReq.timeout(this); - else - this.handleNext(); - }; + this.timeoutRunner = getTimeoutRunnable(); } public Request(HuaweiSupportProvider supportProvider, nodomain.freeyourgadget.gadgetbridge.service.btle.TransactionBuilder builder) { @@ -160,13 +164,7 @@ public class Request { this.isSelfQueue = true; this.handler = new Handler(Looper.getMainLooper()); - this.timeoutRunner = () -> { - LOG.debug("Timeout on Service {} command {}", this.serviceId, this.commandId); - if (finalizeReq != null) - finalizeReq.timeout(this); - else - this.handleNext(); - }; + this.timeoutRunner = getTimeoutRunnable(); } public Request(HuaweiSupportProvider supportProvider) { @@ -181,13 +179,7 @@ public class Request { this.isSelfQueue = true; this.handler = new Handler(Looper.getMainLooper()); - this.timeoutRunner = () -> { - LOG.debug("Timeout on Service {} command {}", this.serviceId, this.commandId); - if (finalizeReq != null) - finalizeReq.timeout(this); - else - this.handleNext(); - }; + this.timeoutRunner = getTimeoutRunnable(); } protected boolean requestSupported() { @@ -275,6 +267,7 @@ public class Request { finalizeReq.call(this); } } + nextRequest = null; } public void setSelfQueue() { @@ -282,8 +275,10 @@ public class Request { } public Request nextRequest(Request req) { - nextRequest = req; - nextRequest.setSelfQueue(); + if (req != null) { + nextRequest = req; + nextRequest.setSelfQueue(); + } return this; }