Skip to content

IO: Improve resource management during file operations#1363

Merged
d4rken merged 1 commit into
mainfrom
io-resource-leases
Aug 9, 2024
Merged

IO: Improve resource management during file operations#1363
d4rken merged 1 commit into
mainfrom
io-resource-leases

Conversation

@d4rken

@d4rken d4rken commented Aug 9, 2024

Copy link
Copy Markdown
Member

While the parent (LocalGateway or PkgOps) is active and they themself as resource are being kept alive, make sure we keep childs like Shizuku or Root sessions alive too. Closing and opening the service connections (releasing the child resources) while the parent resource is alive, just adds extra churn.

Also see #1360

18:46:35.645 SDMSE:TaskManager:SR                 D  get(205551414): Reviving SharedResource
18:46:35.650 SDMSE:TaskManager:SR                 D  Acquiring shared resource...
18:46:35.653 SDMSE:AppCleaner:SR                  D  get(163473936): Reviving SharedResource
18:46:35.656 SDMSE:AppCleaner:SR                  D  Acquiring shared resource...
18:46:35.664 SDMSE:CSI:FileForensics:SR           D  get(54980210): Reviving SharedResource
18:46:35.666 SDMSE:CSI:FileForensics:SR           D  Acquiring shared resource...
18:46:35.670 SDMSE:Gateway:Switch:SR              D  get(214268849): Reviving SharedResource
18:46:35.673 SDMSE:Gateway:Switch:SR              D  Acquiring shared resource...
18:46:35.676 SDMSE:Pkg:Ops:SR                     D  get(250454437): Reviving SharedResource
18:46:35.679 SDMSE:Pkg:Ops:SR                     D  Acquiring shared resource...
18:46:35.747 SDMSE:Gateway:Local:SR               D  get(252054746): Reviving SharedResource
18:46:35.749 SDMSE:Gateway:Local:SR               D  Acquiring shared resource...
18:46:35.788 SDMSE:Shizuku:Service:Client:SR      D  get(27747328): Reviving SharedResource
18:46:35.790 SDMSE:Shizuku:Service:Client:SR      D  Acquiring shared resource...
18:46:45.315 SDMSE:TaskManager                    D  Releasing resource lock for 267d2fe2-b3f0-4f94-90f6-2a1369b22794
18:46:46.328 SDMSE:TaskManager:SR                 D  Shared resource flow completed.
18:46:47.356 SDMSE:AppCleaner:SR                  D  Shared resource flow completed.
18:46:48.376 SDMSE:CSI:FileForensics:SR           D  Shared resource flow completed.
18:46:49.387 SDMSE:Pkg:Ops:SR                     D  Shared resource flow completed.
18:46:49.390 SDMSE:Gateway:Switch:SR              D  Shared resource flow completed.
18:46:50.397 SDMSE:Gateway:Local:SR               D  Shared resource flow completed.
18:46:51.441 SDMSE:Shizuku:Service:Client:SR      D  Shared resource flow completed.

While the parent (LocalGateway or PkgOps) is active and they themself as resource are being kept alive, make sure we keep childs like Shizuku or Root sessions alive too.
Closing and opening the service connections (releasing the child resources) while the parent resource is alive, just adds extra churn.

Also see #1360

```
18:46:35.645 SDMSE:TaskManager:SR                 D  get(205551414): Reviving SharedResource
18:46:35.650 SDMSE:TaskManager:SR                 D  Acquiring shared resource...
18:46:35.653 SDMSE:AppCleaner:SR                  D  get(163473936): Reviving SharedResource
18:46:35.656 SDMSE:AppCleaner:SR                  D  Acquiring shared resource...
18:46:35.664 SDMSE:CSI:FileForensics:SR           D  get(54980210): Reviving SharedResource
18:46:35.666 SDMSE:CSI:FileForensics:SR           D  Acquiring shared resource...
18:46:35.670 SDMSE:Gateway:Switch:SR              D  get(214268849): Reviving SharedResource
18:46:35.673 SDMSE:Gateway:Switch:SR              D  Acquiring shared resource...
18:46:35.676 SDMSE:Pkg:Ops:SR                     D  get(250454437): Reviving SharedResource
18:46:35.679 SDMSE:Pkg:Ops:SR                     D  Acquiring shared resource...
18:46:35.747 SDMSE:Gateway:Local:SR               D  get(252054746): Reviving SharedResource
18:46:35.749 SDMSE:Gateway:Local:SR               D  Acquiring shared resource...
18:46:35.788 SDMSE:Shizuku:Service:Client:SR      D  get(27747328): Reviving SharedResource
18:46:35.790 SDMSE:Shizuku:Service:Client:SR      D  Acquiring shared resource...
18:46:45.315 SDMSE:TaskManager                    D  Releasing resource lock for 267d2fe2-b3f0-4f94-90f6-2a1369b22794
18:46:46.328 SDMSE:TaskManager:SR                 D  Shared resource flow completed.
18:46:47.356 SDMSE:AppCleaner:SR                  D  Shared resource flow completed.
18:46:48.376 SDMSE:CSI:FileForensics:SR           D  Shared resource flow completed.
18:46:49.387 SDMSE:Pkg:Ops:SR                     D  Shared resource flow completed.
18:46:49.390 SDMSE:Gateway:Switch:SR              D  Shared resource flow completed.
18:46:50.397 SDMSE:Gateway:Local:SR               D  Shared resource flow completed.
18:46:51.441 SDMSE:Shizuku:Service:Client:SR      D  Shared resource flow completed.
```
@d4rken d4rken added enhancement New feature, request, improvement or optimization Root ADB ADB/Shizuku related labels Aug 9, 2024
@d4rken d4rken merged commit fa2488f into main Aug 9, 2024
@d4rken d4rken deleted the io-resource-leases branch August 9, 2024 19:05
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

ADB ADB/Shizuku related enhancement New feature, request, improvement or optimization Root

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant