Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[BUG] All processes are loading modules #771

Closed
elesbb opened this issue Dec 26, 2020 · 16 comments
Closed

[BUG] All processes are loading modules #771

elesbb opened this issue Dec 26, 2020 · 16 comments
Labels
wontfix This will not be worked on

Comments

@elesbb
Copy link

elesbb commented Dec 26, 2020

Normally, only Zygote loads the modules. This version (93-v0.5.1.3_4646-master (SandHook)) is having every single process load modules from the apks. Just look at the log, and you will see what I mean.

all_loaded.txt

@Mikanoshi
Copy link

Mikanoshi commented Dec 26, 2020

Ha, welcome to the nightmare. That's how EdXposed works now to keep zygote process "clean".
initZygote is being executed for every process separately. This introduces an unavoidable launch delay and litters logs with useless entries, basically a permanent app list mode. Have fun scrolling through all these module loading messages to find an actual error.

@elesbb
Copy link
Author

elesbb commented Dec 26, 2020

Ha, welcome to the nightmare. That's how EdXposed works now to keep zygote process "clean".
initZygote is being executed for every process separately. This introduces an unavoidable launch delay and litters logs with useless entries, basically a permanent app list mode. Have fun scrolling through all these module loading messages to find an actual error.

The error isn't too hard to find in logcat with filters.

This method of hooking now breaks my module though. I have variables that are popping up as "null" when they never did before. My guess is for every process now loading the module, a new instance of that xposed class is created and some instances variables are not set, thus resulting in them being null.

I don't understand, what are the "benefits" of a "clean" zygote process? SafetyNet?

I could potentially set my variables to static but that would open up the possibility for memory leaks, speaking of, having every single process load every single module, is that not more taxing on the system? I definitely noticed the launch delay and thought something was janked in my phone. I do not like this new way of hooking. What was wrong with toggling app list mode for certain apps?

@Mikanoshi
Copy link

Mikanoshi commented Dec 26, 2020

The error isn't too hard to find in logcat with filters.

I have an option in my module to send report to developer, it asks hooked system process to collect Xposed log, then compresses it and uploads to my server. Now logs are filled with megabytes of strings about modules being loaded :)

I don't understand, what are the "benefits" of a "clean" zygote process? SafetyNet?

Yes, and avoiding some apps like GCam crashing. They might detect that classes in a process were tampered with.
Totally useless for me as my GCam works perfectly fine and I don't use Google Pay or anything else that requires Safety Net.

I could potentially set my variables to static

If they are set in one method and then used in another you probably should.
And use new XSharedPreferences, because EdXposed now also lacks SELinux rule that allows system processes to read app data.

What was wrong with toggling app list mode for certain apps?

Idunno :)

@yujincheng08
Copy link
Contributor

This is expected. Won't fix.

@kotori2 kotori2 added the wontfix This will not be worked on label Dec 27, 2020
@kotori2 kotori2 closed this as completed Dec 27, 2020
@elesbb
Copy link
Author

elesbb commented Dec 27, 2020

This is expected. Won't fix.

Well why are variables becoming null all of a sudden? There is really no "easy" fix for it either as to completely control everything, one would need to write if (myVariable == null) return;, or I guess the easier thing would be to surround the main hook with a try catch block.

I really don't think this method is good on the device. Every single process is going to be loading another process (the xposed module) which is going to fill up the RAM and consume resources faster. Why was this the default instead of having the user select which apps to do this with?

@Mikanoshi
Copy link

Show your code, it's unclear what variables you are talking about. If you assign them in one process and then use in another then they will be null, you have to assign them again for each process.

@elesbb
Copy link
Author

elesbb commented Dec 27, 2020

Show your code, it's unclear what variables you are talking about. If you assign them in one process and then use in another then they will be null, you have to assign them again for each process.

Error:

12-26 14:47:25.272  4888  4888 E EdXposed-Bridge: java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.RelativeLayout.setLayoutParams(android.view.ViewGroup$LayoutParams)' on a null object reference
12-26 14:47:25.272  4888  4888 E EdXposed-Bridge: 	at com.elesbb.keyboardcustomizer.XposedInit$11.afterHookedMethod(XposedInit.java:455)
12-26 14:47:25.272  4888  4888 E EdXposed-Bridge: 	at de.robv.android.xposed.XC_MethodHook.callAfterHookedMethod(XC_MethodHook.java:68)
12-26 14:47:25.272  4888  4888 E EdXposed-Bridge: 	at com.swift.sandhook.xposedcompat.hookstub.HookStubManager.hookBridge(HookStubManager.java:394)
12-26 14:47:25.272  4888  4888 E EdXposed-Bridge: 	at SandHookerNew_4mcon2opqkutkjmvgo9idi9hkl.hook(Unknown Source:63)
12-26 14:47:25.272  4888  4888 E EdXposed-Bridge: 	at com.dexilog.smartkeyboard.ui.MainKeyboardView.a(MainKeyboardView.java:1435)
12-26 14:47:25.272  4888  4888 E EdXposed-Bridge: 	at com.dexilog.smartkeyboard.ui.MainKeyboardView.c(MainKeyboardView.java:1400)
12-26 14:47:25.272  4888  4888 E EdXposed-Bridge: 	at java.lang.reflect.Method.invoke(Native Method)
12-26 14:47:25.272  4888  4888 E EdXposed-Bridge: 	at com.swift.sandhook.SandHook.callOriginMethod(SandHook.java:183)
12-26 14:47:25.272  4888  4888 E EdXposed-Bridge: 	at com.swift.sandhook.xposedcompat.hookstub.HookStubManager.hookBridge(HookStubManager.java:380)
12-26 14:47:25.272  4888  4888 E EdXposed-Bridge: 	at SandHookerNew_4f7qtfq5r09r656kguaf1ei6s4.hook(Unknown Source:51)
12-26 14:47:25.272  4888  4888 E EdXposed-Bridge: 	at com.dexilog.smartkeyboard.ui.MainKeyboardView.a(MainKeyboardView.java:60)
12-26 14:47:25.272  4888  4888 E EdXposed-Bridge: 	at com.dexilog.smartkeyboard.ui.MainKeyboardView$1.handleMessage(MainKeyboardView.java:275)
12-26 14:47:25.272  4888  4888 E EdXposed-Bridge: 	at android.os.Handler.dispatchMessage(Handler.java:107)
12-26 14:47:25.272  4888  4888 E EdXposed-Bridge: 	at android.os.Looper.loop(Looper.java:237)
12-26 14:47:25.272  4888  4888 E EdXposed-Bridge: 	at android.app.ActivityThread.main(ActivityThread.java:8167)
12-26 14:47:25.272  4888  4888 E EdXposed-Bridge: 	at java.lang.reflect.Method.invoke(Native Method)
12-26 14:47:25.272  4888  4888 E EdXposed-Bridge: 	at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:496)
12-26 14:47:25.272  4888  4888 E EdXposed-Bridge: 	at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1100)

Code:

# This happens inside "onCreate" of the KeyboardView
myNewCustomEmoji = getMainLayout(context, horizontal, pager);

Where the crash happens:

# Happens inside another method of the same hooked process.
myNewCustomEmoji.setLayoutParams(params);

This code was not a problem until recently. I can guarantee you what is happening is the process crashing did not initialize in the same manner as the main one which actually hooks the keyboard. And this causes the variable to be null

@Mikanoshi
Copy link

Where is myNewCustomEmoji declared? It should be either static or handled by XposedHelpers.setAdditionalInstanceField()/getAdditionalInstanceField().

@elesbb
Copy link
Author

elesbb commented Dec 27, 2020

Where is myNewCustomEmoji declared? It should be either static or handled by XposedHelpers.setAdditionalInstanceField()/getAdditionalInstanceField().

It is declared at the very top of the class right after the implements, so it is class wide accessible. Even if I used XposedHelpers.set(get)AdditionalInstanceField it would still be null for some processes.

public class XposedInit implements IXposedHookLoadPackage, IXposedHookZygoteInit, IXposedHookInitPackageResources {
...
    private RelativeLayout myNewCustomEmoji;

What is happening is the "onCreate" method is hooked, fills myNewCustomEmoji variable for all instances that have loaded my module, "onCreate" method occurs only once, so any processes loading my module AFTER "onCreate" runs, will always return myNewCustomEmoji as null, which is exactly what is happening.

Where it initializes the myNewCustomEmoji variable, and where it accesses it are two different classes, which would be perfectly fine if I were modding the apk directly.

My point is still - I do not think having every single process load every single module is a smart thing to do, it will be loading things not even relevant to the process. Only processes which have hooks related to that process should be loaded for that process. If you keep creating instances of classes, you will have memory leaks and other issues like the one I am having. I'm not saying we should "go back" to loading zygote, but filter the modules loaded by a specific process to only load modules that hook that process.

@Mikanoshi
Copy link

I'm not sure I understand, need a full code. What instances? EdXposed 0.5 no longer injects classes into zygote before fork, so you cannot load something in initZygote and then use it in another processes. Each process calls its own initZygote.
Just make variable static and it should work, setAdditionalInstanceField should already work. If you hook onCreate of some package in handleLoadPackage then variable assigned there will be available in this entire package.

@elesbb
Copy link
Author

elesbb commented Dec 27, 2020

I'm not sure I understand, need a full code. What instances? EdXposed 0.5 no longer injects classes into zygote before fork, so you cannot load something in initZygote and then use it in another processes. Each process calls its own initZygote.
Just make variable static and it should work, setAdditionalInstanceField should already work. If you hook onCreate of some package in handleLoadPackage then variable assigned there will be available in this entire package.

Exactly, but this isn't the case anymore because every process loads an instance of your module. I cannot make the variable static because it holds a "context" object that can become a memory leak.

Each process is loading an instance of the module. And as you said, you cannot access fields across processes (which Is NOT what I am trying to do.)

I'll give an example with 3 processes that load xposed modules. Process A, Process HOOKED, and Process B. HOOKED is clearly the one I want to hook.

Process A loads my module. Nothing happens, not the process I want, however, there is STILL an instance of my module created (the xposed class, this includes all variables declared at the top of the class).
Process HOOKED now loads my module, a new instance of the xposed class is created, the "onCreate" method runs, my variable is filled. All is good.
Process B now loads my module, yet another instance of my xposed.class is created.

Process HOOKED runs the second method I am hooking, in this method, I access the variable that was filled in the onCreate method. Process HOOKED and A have no problem, but Process B crashes with a null pointer exception because it was not loaded in time.

Basically, as you said, every process now becomes its own zygote, which is causing the modules to constantly be loaded by every single process. What needs to happen is a filter to only allow a process to load a module if it has any hooks for that process.

@Mikanoshi
Copy link

Process HOOKED runs the second method I am hooking, in this method, I access the variable that was filled in the onCreate method.
Process HOOKED and A have no problem, but Process B crashes with a null pointer exception because it was not loaded in time.

Why process A and B are even mentioned here? You don't want to hook them, variables there are null, it was like that in EdXposed 0.4 too. Don't use variable in processes A/B and there won't be any crashes.

What needs to happen is a filter to only allow a process to load a module if it has any hooks for that process.

0.4 loaded modules in zygote and then they were forked to other processes, your class was in all of them too.
initZygote has no package differentiation, and a lot of my mods require hooks there to be available in every process, because they hook Android framework classes.

@elesbb
Copy link
Author

elesbb commented Dec 28, 2020

Process HOOKED runs the second method I am hooking, in this method, I access the variable that was filled in the onCreate method.
Process HOOKED and A have no problem, but Process B crashes with a null pointer exception because it was not loaded in time.

Why process A and B are even mentioned here? You don't want to hook them, variables there are null, it was like that in EdXposed 0.4 too. Don't use variable in processes A/B and there won't be any crashes.

What needs to happen is a filter to only allow a process to load a module if it has any hooks for that process.

0.4 loaded modules in zygote and then they were forked to other processes, your class was in all of them too.
initZygote has no package differentiation, and a lot of my mods require hooks there to be available in every process, because they hook Android framework classes.

Man I really don't know how to explain this. Process A and B are mentioned because they load my module now. Zygote itself would create an instance of the Xposed.class (whatever is set in the xposed_init file inside your apk assets dir), this class is now initialized multiple times, not just once. The difference between 0.4 and 0.5 is WHEN the xposed class is loaded. The fact that making the variable static would fix it is proof multiple instances of my class are loaded, where before, it was only one.

@Mikanoshi
Copy link

That's how it works now. Why do you have crashes is still unclear, you assign and use variable in a HOOKED process, it's not involved with A and B.

@elesbb
Copy link
Author

elesbb commented Dec 28, 2020

That's how it works now. Why do you have crashes is still unclear, you assign and use variable in a HOOKED process, it's not involved with A and B.

The reason for the crashes is because of the multiple instances of my xposed.class being created. With just one created, it is fine.

When my module accesses the variable, it is null, because that module got loaded AFTER the variable was filled, so everything is null again.

It's basically doing this:

MyXposedClass myClass = new MyXposedClass(); <-- First instance by process A
MyXposedClass myClass = new MyXposedClass(); <-- Second instance by process HOOKED
MyXposedClass myClass = new MyXposedClass(); <-- Third instance by process B

Anything that creates a new instance of the XposedClass AFTER HOOKED process does, will never have the variables assigned to them. I also don't think its healthy on the resources for every single process to be creating a new xposed class instance.

Before, only zygote created an instance of the MyXPosedClass();, and then forked that to the processes.
@kotori2, Am I understanding this correctly?

@Mikanoshi
Copy link

Mikanoshi commented Dec 28, 2020

Anything that creates a new instance of the XposedClass AFTER HOOKED process does, will never have the variables assigned to them.

Those instances are separated into different processes, both A and B will have variable as null because you are not assigning anything there. This cannot cause any crashes unless you deliberately trying to use such variables without assigning something to them first.
Are you saying that in EdXposed 0.4 in regular mode you could assign variable in one process and it became available in another? I thought that forking is copy-on-write, so the moment you change something it will just create a local copy of that change.

SekiBetu added a commit to SekiBetu/SekiBetu that referenced this issue Apr 2, 2021
…—mlgmxyysd(ElderDrivers/EdXposed/issues/837)

ElderDrivers/EdXposed#1
ElderDrivers/EdXposed#2
ElderDrivers/EdXposed#3
ElderDrivers/EdXposed#4
ElderDrivers/EdXposed#5
ElderDrivers/EdXposed#6
ElderDrivers/EdXposed#7
ElderDrivers/EdXposed#8
ElderDrivers/EdXposed#9
ElderDrivers/EdXposed#10
ElderDrivers/EdXposed#11
ElderDrivers/EdXposed#12
ElderDrivers/EdXposed#13
ElderDrivers/EdXposed#14
ElderDrivers/EdXposed#15
ElderDrivers/EdXposed#16
ElderDrivers/EdXposed#17
ElderDrivers/EdXposed#18
ElderDrivers/EdXposed#19
ElderDrivers/EdXposed#20
ElderDrivers/EdXposed#21
ElderDrivers/EdXposed#22
ElderDrivers/EdXposed#23
ElderDrivers/EdXposed#24
ElderDrivers/EdXposed#25
ElderDrivers/EdXposed#26
ElderDrivers/EdXposed#27
ElderDrivers/EdXposed#28
ElderDrivers/EdXposed#29
ElderDrivers/EdXposed#30
ElderDrivers/EdXposed#31
ElderDrivers/EdXposed#32
ElderDrivers/EdXposed#33
ElderDrivers/EdXposed#34
ElderDrivers/EdXposed#35
ElderDrivers/EdXposed#36
ElderDrivers/EdXposed#37
ElderDrivers/EdXposed#38
ElderDrivers/EdXposed#39
ElderDrivers/EdXposed#40
ElderDrivers/EdXposed#41
ElderDrivers/EdXposed#42
ElderDrivers/EdXposed#43
ElderDrivers/EdXposed#44
ElderDrivers/EdXposed#45
ElderDrivers/EdXposed#46
ElderDrivers/EdXposed#47
ElderDrivers/EdXposed#48
ElderDrivers/EdXposed#49
ElderDrivers/EdXposed#50
ElderDrivers/EdXposed#51
ElderDrivers/EdXposed#52
ElderDrivers/EdXposed#53
ElderDrivers/EdXposed#54
ElderDrivers/EdXposed#55
ElderDrivers/EdXposed#56
ElderDrivers/EdXposed#57
ElderDrivers/EdXposed#58
ElderDrivers/EdXposed#59
ElderDrivers/EdXposed#60
ElderDrivers/EdXposed#61
ElderDrivers/EdXposed#62
ElderDrivers/EdXposed#63
ElderDrivers/EdXposed#64
ElderDrivers/EdXposed#65
ElderDrivers/EdXposed#66
ElderDrivers/EdXposed#67
ElderDrivers/EdXposed#68
ElderDrivers/EdXposed#69
ElderDrivers/EdXposed#70
ElderDrivers/EdXposed#71
ElderDrivers/EdXposed#72
ElderDrivers/EdXposed#73
ElderDrivers/EdXposed#74
ElderDrivers/EdXposed#75
ElderDrivers/EdXposed#76
ElderDrivers/EdXposed#77
ElderDrivers/EdXposed#78
ElderDrivers/EdXposed#79
ElderDrivers/EdXposed#80
ElderDrivers/EdXposed#81
ElderDrivers/EdXposed#82
ElderDrivers/EdXposed#83
ElderDrivers/EdXposed#84
ElderDrivers/EdXposed#85
ElderDrivers/EdXposed#86
ElderDrivers/EdXposed#87
ElderDrivers/EdXposed#88
ElderDrivers/EdXposed#89
ElderDrivers/EdXposed#90
ElderDrivers/EdXposed#91
ElderDrivers/EdXposed#92
ElderDrivers/EdXposed#93
ElderDrivers/EdXposed#94
ElderDrivers/EdXposed#95
ElderDrivers/EdXposed#96
ElderDrivers/EdXposed#97
ElderDrivers/EdXposed#98
ElderDrivers/EdXposed#99
ElderDrivers/EdXposed#100
ElderDrivers/EdXposed#101
ElderDrivers/EdXposed#102
ElderDrivers/EdXposed#103
ElderDrivers/EdXposed#104
ElderDrivers/EdXposed#105
ElderDrivers/EdXposed#106
ElderDrivers/EdXposed#107
ElderDrivers/EdXposed#108
ElderDrivers/EdXposed#109
ElderDrivers/EdXposed#110
ElderDrivers/EdXposed#111
ElderDrivers/EdXposed#112
ElderDrivers/EdXposed#113
ElderDrivers/EdXposed#114
ElderDrivers/EdXposed#115
ElderDrivers/EdXposed#116
ElderDrivers/EdXposed#117
ElderDrivers/EdXposed#118
ElderDrivers/EdXposed#119
ElderDrivers/EdXposed#120
ElderDrivers/EdXposed#121
ElderDrivers/EdXposed#122
ElderDrivers/EdXposed#123
ElderDrivers/EdXposed#124
ElderDrivers/EdXposed#125
ElderDrivers/EdXposed#126
ElderDrivers/EdXposed#127
ElderDrivers/EdXposed#128
ElderDrivers/EdXposed#129
ElderDrivers/EdXposed#130
ElderDrivers/EdXposed#131
ElderDrivers/EdXposed#132
ElderDrivers/EdXposed#133
ElderDrivers/EdXposed#134
ElderDrivers/EdXposed#135
ElderDrivers/EdXposed#136
ElderDrivers/EdXposed#137
ElderDrivers/EdXposed#138
ElderDrivers/EdXposed#139
ElderDrivers/EdXposed#140
ElderDrivers/EdXposed#141
ElderDrivers/EdXposed#142
ElderDrivers/EdXposed#143
ElderDrivers/EdXposed#144
ElderDrivers/EdXposed#145
ElderDrivers/EdXposed#146
ElderDrivers/EdXposed#147
ElderDrivers/EdXposed#148
ElderDrivers/EdXposed#149
ElderDrivers/EdXposed#150
ElderDrivers/EdXposed#151
ElderDrivers/EdXposed#152
ElderDrivers/EdXposed#153
ElderDrivers/EdXposed#154
ElderDrivers/EdXposed#155
ElderDrivers/EdXposed#156
ElderDrivers/EdXposed#157
ElderDrivers/EdXposed#158
ElderDrivers/EdXposed#159
ElderDrivers/EdXposed#160
ElderDrivers/EdXposed#161
ElderDrivers/EdXposed#162
ElderDrivers/EdXposed#163
https://github.com/ElderDrivers/EdXposed/issues/164
https://github.com/ElderDrivers/EdXposed/issues/165
ElderDrivers/EdXposed#166
ElderDrivers/EdXposed#167
ElderDrivers/EdXposed#168
https://github.com/ElderDrivers/EdXposed/issues/169
ElderDrivers/EdXposed#170
ElderDrivers/EdXposed#171
ElderDrivers/EdXposed#172
ElderDrivers/EdXposed#173
ElderDrivers/EdXposed#174
ElderDrivers/EdXposed#175
ElderDrivers/EdXposed#176
ElderDrivers/EdXposed#177
ElderDrivers/EdXposed#178
ElderDrivers/EdXposed#179
ElderDrivers/EdXposed#180
ElderDrivers/EdXposed#181
ElderDrivers/EdXposed#182
ElderDrivers/EdXposed#183
ElderDrivers/EdXposed#184
ElderDrivers/EdXposed#185
ElderDrivers/EdXposed#186
ElderDrivers/EdXposed#187
ElderDrivers/EdXposed#188
ElderDrivers/EdXposed#189
ElderDrivers/EdXposed#190
ElderDrivers/EdXposed#191
ElderDrivers/EdXposed#192
ElderDrivers/EdXposed#193
ElderDrivers/EdXposed#194
ElderDrivers/EdXposed#195
ElderDrivers/EdXposed#196
ElderDrivers/EdXposed#197
ElderDrivers/EdXposed#198
ElderDrivers/EdXposed#199
ElderDrivers/EdXposed#200
ElderDrivers/EdXposed#201
ElderDrivers/EdXposed#202
ElderDrivers/EdXposed#203
ElderDrivers/EdXposed#204
ElderDrivers/EdXposed#205
ElderDrivers/EdXposed#206
ElderDrivers/EdXposed#207
ElderDrivers/EdXposed#208
ElderDrivers/EdXposed#209
ElderDrivers/EdXposed#210
ElderDrivers/EdXposed#211
ElderDrivers/EdXposed#212
ElderDrivers/EdXposed#213
ElderDrivers/EdXposed#214
ElderDrivers/EdXposed#215
ElderDrivers/EdXposed#216
ElderDrivers/EdXposed#217
ElderDrivers/EdXposed#218
ElderDrivers/EdXposed#219
ElderDrivers/EdXposed#220
ElderDrivers/EdXposed#221
ElderDrivers/EdXposed#222
ElderDrivers/EdXposed#223
ElderDrivers/EdXposed#224
ElderDrivers/EdXposed#225
ElderDrivers/EdXposed#226
ElderDrivers/EdXposed#227
ElderDrivers/EdXposed#228
ElderDrivers/EdXposed#229
ElderDrivers/EdXposed#230
ElderDrivers/EdXposed#231
ElderDrivers/EdXposed#232
ElderDrivers/EdXposed#233
ElderDrivers/EdXposed#234
ElderDrivers/EdXposed#235
ElderDrivers/EdXposed#236
ElderDrivers/EdXposed#237
ElderDrivers/EdXposed#238
ElderDrivers/EdXposed#239
ElderDrivers/EdXposed#240
ElderDrivers/EdXposed#241
ElderDrivers/EdXposed#242
ElderDrivers/EdXposed#243
ElderDrivers/EdXposed#244
ElderDrivers/EdXposed#245
ElderDrivers/EdXposed#246
ElderDrivers/EdXposed#247
ElderDrivers/EdXposed#248
ElderDrivers/EdXposed#249
ElderDrivers/EdXposed#250
ElderDrivers/EdXposed#251
ElderDrivers/EdXposed#252
ElderDrivers/EdXposed#253
ElderDrivers/EdXposed#254
ElderDrivers/EdXposed#255
ElderDrivers/EdXposed#256
ElderDrivers/EdXposed#257
ElderDrivers/EdXposed#258
ElderDrivers/EdXposed#259
ElderDrivers/EdXposed#260
ElderDrivers/EdXposed#261
ElderDrivers/EdXposed#262
ElderDrivers/EdXposed#263
ElderDrivers/EdXposed#264
ElderDrivers/EdXposed#265
ElderDrivers/EdXposed#266
ElderDrivers/EdXposed#267
ElderDrivers/EdXposed#268
ElderDrivers/EdXposed#269
ElderDrivers/EdXposed#270
ElderDrivers/EdXposed#271
ElderDrivers/EdXposed#272
ElderDrivers/EdXposed#273
ElderDrivers/EdXposed#274
ElderDrivers/EdXposed#275
ElderDrivers/EdXposed#276
ElderDrivers/EdXposed#277
ElderDrivers/EdXposed#278
ElderDrivers/EdXposed#279
ElderDrivers/EdXposed#280
ElderDrivers/EdXposed#281
ElderDrivers/EdXposed#282
ElderDrivers/EdXposed#283
ElderDrivers/EdXposed#284
ElderDrivers/EdXposed#285
ElderDrivers/EdXposed#286
ElderDrivers/EdXposed#287
ElderDrivers/EdXposed#288
ElderDrivers/EdXposed#289
ElderDrivers/EdXposed#290
ElderDrivers/EdXposed#291
ElderDrivers/EdXposed#292
ElderDrivers/EdXposed#293
ElderDrivers/EdXposed#294
ElderDrivers/EdXposed#295
ElderDrivers/EdXposed#296
ElderDrivers/EdXposed#297
ElderDrivers/EdXposed#298
ElderDrivers/EdXposed#299
ElderDrivers/EdXposed#300
ElderDrivers/EdXposed#301
ElderDrivers/EdXposed#302
ElderDrivers/EdXposed#303
ElderDrivers/EdXposed#304
ElderDrivers/EdXposed#305
https://github.com/ElderDrivers/EdXposed/issues/306
ElderDrivers/EdXposed#307
ElderDrivers/EdXposed#308
ElderDrivers/EdXposed#309
ElderDrivers/EdXposed#310
ElderDrivers/EdXposed#311
ElderDrivers/EdXposed#312
ElderDrivers/EdXposed#313
ElderDrivers/EdXposed#314
ElderDrivers/EdXposed#315
ElderDrivers/EdXposed#316
ElderDrivers/EdXposed#317
ElderDrivers/EdXposed#318
ElderDrivers/EdXposed#319
ElderDrivers/EdXposed#320
ElderDrivers/EdXposed#321
ElderDrivers/EdXposed#322
ElderDrivers/EdXposed#323
ElderDrivers/EdXposed#324
ElderDrivers/EdXposed#325
ElderDrivers/EdXposed#326
ElderDrivers/EdXposed#327
ElderDrivers/EdXposed#328
ElderDrivers/EdXposed#329
ElderDrivers/EdXposed#330
ElderDrivers/EdXposed#331
ElderDrivers/EdXposed#332
ElderDrivers/EdXposed#333
ElderDrivers/EdXposed#334
ElderDrivers/EdXposed#335
ElderDrivers/EdXposed#336
ElderDrivers/EdXposed#337
ElderDrivers/EdXposed#338
ElderDrivers/EdXposed#339
ElderDrivers/EdXposed#340
ElderDrivers/EdXposed#341
ElderDrivers/EdXposed#342
ElderDrivers/EdXposed#343
ElderDrivers/EdXposed#344
ElderDrivers/EdXposed#345
ElderDrivers/EdXposed#346
ElderDrivers/EdXposed#347
ElderDrivers/EdXposed#348
ElderDrivers/EdXposed#349
ElderDrivers/EdXposed#350
ElderDrivers/EdXposed#351
ElderDrivers/EdXposed#352
ElderDrivers/EdXposed#353
ElderDrivers/EdXposed#354
ElderDrivers/EdXposed#355
ElderDrivers/EdXposed#356
ElderDrivers/EdXposed#357
ElderDrivers/EdXposed#358
ElderDrivers/EdXposed#359
ElderDrivers/EdXposed#360
ElderDrivers/EdXposed#361
ElderDrivers/EdXposed#362
ElderDrivers/EdXposed#363
ElderDrivers/EdXposed#364
ElderDrivers/EdXposed#365
ElderDrivers/EdXposed#366
ElderDrivers/EdXposed#367
ElderDrivers/EdXposed#368
ElderDrivers/EdXposed#369
ElderDrivers/EdXposed#370
ElderDrivers/EdXposed#371
ElderDrivers/EdXposed#372
ElderDrivers/EdXposed#373
ElderDrivers/EdXposed#374
ElderDrivers/EdXposed#375
ElderDrivers/EdXposed#376
ElderDrivers/EdXposed#377
ElderDrivers/EdXposed#378
ElderDrivers/EdXposed#379
ElderDrivers/EdXposed#380
ElderDrivers/EdXposed#381
ElderDrivers/EdXposed#382
ElderDrivers/EdXposed#383
ElderDrivers/EdXposed#384
ElderDrivers/EdXposed#385
ElderDrivers/EdXposed#386
ElderDrivers/EdXposed#387
ElderDrivers/EdXposed#388
ElderDrivers/EdXposed#389
ElderDrivers/EdXposed#390
ElderDrivers/EdXposed#391
ElderDrivers/EdXposed#392
ElderDrivers/EdXposed#393
ElderDrivers/EdXposed#394
ElderDrivers/EdXposed#395
ElderDrivers/EdXposed#396
ElderDrivers/EdXposed#397
ElderDrivers/EdXposed#398
ElderDrivers/EdXposed#399
ElderDrivers/EdXposed#400
ElderDrivers/EdXposed#401
ElderDrivers/EdXposed#402
ElderDrivers/EdXposed#403
ElderDrivers/EdXposed#404
ElderDrivers/EdXposed#405
ElderDrivers/EdXposed#406
ElderDrivers/EdXposed#407
ElderDrivers/EdXposed#408
ElderDrivers/EdXposed#409
ElderDrivers/EdXposed#410
ElderDrivers/EdXposed#411
ElderDrivers/EdXposed#412
ElderDrivers/EdXposed#413
ElderDrivers/EdXposed#414
ElderDrivers/EdXposed#415
ElderDrivers/EdXposed#416
ElderDrivers/EdXposed#417
ElderDrivers/EdXposed#418
ElderDrivers/EdXposed#419
ElderDrivers/EdXposed#420
ElderDrivers/EdXposed#421
ElderDrivers/EdXposed#422
ElderDrivers/EdXposed#423
ElderDrivers/EdXposed#424
ElderDrivers/EdXposed#425
ElderDrivers/EdXposed#426
ElderDrivers/EdXposed#427
ElderDrivers/EdXposed#428
ElderDrivers/EdXposed#429
ElderDrivers/EdXposed#430
ElderDrivers/EdXposed#431
ElderDrivers/EdXposed#432
ElderDrivers/EdXposed#433
ElderDrivers/EdXposed#434
ElderDrivers/EdXposed#435
ElderDrivers/EdXposed#436
ElderDrivers/EdXposed#437
ElderDrivers/EdXposed#438
ElderDrivers/EdXposed#439
ElderDrivers/EdXposed#440
ElderDrivers/EdXposed#441
ElderDrivers/EdXposed#442
ElderDrivers/EdXposed#443
ElderDrivers/EdXposed#444
ElderDrivers/EdXposed#445
ElderDrivers/EdXposed#446
ElderDrivers/EdXposed#447
ElderDrivers/EdXposed#448
ElderDrivers/EdXposed#449
ElderDrivers/EdXposed#450
ElderDrivers/EdXposed#451
ElderDrivers/EdXposed#452
ElderDrivers/EdXposed#453
ElderDrivers/EdXposed#454
ElderDrivers/EdXposed#455
ElderDrivers/EdXposed#456
ElderDrivers/EdXposed#457
ElderDrivers/EdXposed#458
ElderDrivers/EdXposed#459
ElderDrivers/EdXposed#460
ElderDrivers/EdXposed#461
ElderDrivers/EdXposed#462
ElderDrivers/EdXposed#463
ElderDrivers/EdXposed#464
ElderDrivers/EdXposed#465
ElderDrivers/EdXposed#466
ElderDrivers/EdXposed#467
ElderDrivers/EdXposed#468
ElderDrivers/EdXposed#469
ElderDrivers/EdXposed#470
ElderDrivers/EdXposed#471
ElderDrivers/EdXposed#472
ElderDrivers/EdXposed#473
ElderDrivers/EdXposed#474
ElderDrivers/EdXposed#475
ElderDrivers/EdXposed#476
ElderDrivers/EdXposed#477
ElderDrivers/EdXposed#478
ElderDrivers/EdXposed#479
ElderDrivers/EdXposed#480
ElderDrivers/EdXposed#481
ElderDrivers/EdXposed#482
ElderDrivers/EdXposed#483
ElderDrivers/EdXposed#484
ElderDrivers/EdXposed#485
ElderDrivers/EdXposed#486
ElderDrivers/EdXposed#487
ElderDrivers/EdXposed#488
ElderDrivers/EdXposed#489
ElderDrivers/EdXposed#490
ElderDrivers/EdXposed#491
ElderDrivers/EdXposed#492
ElderDrivers/EdXposed#493
ElderDrivers/EdXposed#494
ElderDrivers/EdXposed#495
ElderDrivers/EdXposed#496
ElderDrivers/EdXposed#497
ElderDrivers/EdXposed#498
ElderDrivers/EdXposed#499
ElderDrivers/EdXposed#500
ElderDrivers/EdXposed#501
ElderDrivers/EdXposed#502
ElderDrivers/EdXposed#503
ElderDrivers/EdXposed#504
ElderDrivers/EdXposed#505
ElderDrivers/EdXposed#506
ElderDrivers/EdXposed#507
ElderDrivers/EdXposed#508
ElderDrivers/EdXposed#509
ElderDrivers/EdXposed#510
ElderDrivers/EdXposed#511
ElderDrivers/EdXposed#512
ElderDrivers/EdXposed#513
ElderDrivers/EdXposed#514
ElderDrivers/EdXposed#515
ElderDrivers/EdXposed#516
ElderDrivers/EdXposed#517
ElderDrivers/EdXposed#518
ElderDrivers/EdXposed#519
ElderDrivers/EdXposed#520
ElderDrivers/EdXposed#521
ElderDrivers/EdXposed#522
ElderDrivers/EdXposed#523
ElderDrivers/EdXposed#524
ElderDrivers/EdXposed#525
ElderDrivers/EdXposed#526
ElderDrivers/EdXposed#527
ElderDrivers/EdXposed#528
ElderDrivers/EdXposed#529
ElderDrivers/EdXposed#530
ElderDrivers/EdXposed#531
ElderDrivers/EdXposed#532
ElderDrivers/EdXposed#533
ElderDrivers/EdXposed#534
ElderDrivers/EdXposed#535
ElderDrivers/EdXposed#536
ElderDrivers/EdXposed#537
ElderDrivers/EdXposed#538
ElderDrivers/EdXposed#539
ElderDrivers/EdXposed#540
ElderDrivers/EdXposed#541
ElderDrivers/EdXposed#542
ElderDrivers/EdXposed#543
ElderDrivers/EdXposed#544
ElderDrivers/EdXposed#545
ElderDrivers/EdXposed#546
ElderDrivers/EdXposed#547
ElderDrivers/EdXposed#548
ElderDrivers/EdXposed#549
ElderDrivers/EdXposed#550
ElderDrivers/EdXposed#551
ElderDrivers/EdXposed#552
ElderDrivers/EdXposed#553
ElderDrivers/EdXposed#554
ElderDrivers/EdXposed#555
ElderDrivers/EdXposed#556
ElderDrivers/EdXposed#557
ElderDrivers/EdXposed#558
ElderDrivers/EdXposed#559
ElderDrivers/EdXposed#560
ElderDrivers/EdXposed#561
ElderDrivers/EdXposed#562
ElderDrivers/EdXposed#563
ElderDrivers/EdXposed#564
ElderDrivers/EdXposed#565
ElderDrivers/EdXposed#566
ElderDrivers/EdXposed#567
ElderDrivers/EdXposed#568
ElderDrivers/EdXposed#569
ElderDrivers/EdXposed#570
ElderDrivers/EdXposed#571
ElderDrivers/EdXposed#572
ElderDrivers/EdXposed#573
ElderDrivers/EdXposed#574
ElderDrivers/EdXposed#575
ElderDrivers/EdXposed#576
ElderDrivers/EdXposed#577
ElderDrivers/EdXposed#578
ElderDrivers/EdXposed#579
ElderDrivers/EdXposed#580
ElderDrivers/EdXposed#581
ElderDrivers/EdXposed#582
ElderDrivers/EdXposed#583
ElderDrivers/EdXposed#584
ElderDrivers/EdXposed#585
ElderDrivers/EdXposed#586
ElderDrivers/EdXposed#587
ElderDrivers/EdXposed#588
ElderDrivers/EdXposed#589
ElderDrivers/EdXposed#590
ElderDrivers/EdXposed#591
ElderDrivers/EdXposed#592
ElderDrivers/EdXposed#593
ElderDrivers/EdXposed#594
ElderDrivers/EdXposed#595
ElderDrivers/EdXposed#596
ElderDrivers/EdXposed#597
ElderDrivers/EdXposed#598
ElderDrivers/EdXposed#599
ElderDrivers/EdXposed#600
ElderDrivers/EdXposed#601
ElderDrivers/EdXposed#602
ElderDrivers/EdXposed#603
ElderDrivers/EdXposed#604
ElderDrivers/EdXposed#605
ElderDrivers/EdXposed#606
ElderDrivers/EdXposed#607
ElderDrivers/EdXposed#608
ElderDrivers/EdXposed#609
ElderDrivers/EdXposed#610
ElderDrivers/EdXposed#611
ElderDrivers/EdXposed#612
ElderDrivers/EdXposed#613
ElderDrivers/EdXposed#614
ElderDrivers/EdXposed#615
ElderDrivers/EdXposed#616
ElderDrivers/EdXposed#617
ElderDrivers/EdXposed#618
ElderDrivers/EdXposed#619
ElderDrivers/EdXposed#620
ElderDrivers/EdXposed#621
ElderDrivers/EdXposed#622
ElderDrivers/EdXposed#623
ElderDrivers/EdXposed#624
ElderDrivers/EdXposed#625
ElderDrivers/EdXposed#626
ElderDrivers/EdXposed#627
ElderDrivers/EdXposed#628
ElderDrivers/EdXposed#629
ElderDrivers/EdXposed#630
ElderDrivers/EdXposed#631
ElderDrivers/EdXposed#632
ElderDrivers/EdXposed#633
ElderDrivers/EdXposed#634
ElderDrivers/EdXposed#635
ElderDrivers/EdXposed#636
ElderDrivers/EdXposed#637
ElderDrivers/EdXposed#638
ElderDrivers/EdXposed#639
ElderDrivers/EdXposed#640
ElderDrivers/EdXposed#641
ElderDrivers/EdXposed#642
ElderDrivers/EdXposed#643
ElderDrivers/EdXposed#644
ElderDrivers/EdXposed#645
ElderDrivers/EdXposed#646
ElderDrivers/EdXposed#647
ElderDrivers/EdXposed#648
ElderDrivers/EdXposed#649
ElderDrivers/EdXposed#650
ElderDrivers/EdXposed#651
ElderDrivers/EdXposed#652
ElderDrivers/EdXposed#653
ElderDrivers/EdXposed#654
ElderDrivers/EdXposed#655
ElderDrivers/EdXposed#656
ElderDrivers/EdXposed#657
ElderDrivers/EdXposed#658
ElderDrivers/EdXposed#659
ElderDrivers/EdXposed#660
ElderDrivers/EdXposed#661
ElderDrivers/EdXposed#662
ElderDrivers/EdXposed#663
ElderDrivers/EdXposed#664
ElderDrivers/EdXposed#665
ElderDrivers/EdXposed#666
ElderDrivers/EdXposed#667
ElderDrivers/EdXposed#668
ElderDrivers/EdXposed#669
ElderDrivers/EdXposed#670
ElderDrivers/EdXposed#671
ElderDrivers/EdXposed#672
ElderDrivers/EdXposed#673
ElderDrivers/EdXposed#674
ElderDrivers/EdXposed#675
ElderDrivers/EdXposed#676
ElderDrivers/EdXposed#677
ElderDrivers/EdXposed#678
ElderDrivers/EdXposed#679
ElderDrivers/EdXposed#680
ElderDrivers/EdXposed#681
ElderDrivers/EdXposed#682
ElderDrivers/EdXposed#683
ElderDrivers/EdXposed#684
ElderDrivers/EdXposed#685
ElderDrivers/EdXposed#686
ElderDrivers/EdXposed#687
ElderDrivers/EdXposed#688
ElderDrivers/EdXposed#689
ElderDrivers/EdXposed#690
ElderDrivers/EdXposed#691
ElderDrivers/EdXposed#692
ElderDrivers/EdXposed#693
ElderDrivers/EdXposed#694
ElderDrivers/EdXposed#695
ElderDrivers/EdXposed#696
ElderDrivers/EdXposed#697
ElderDrivers/EdXposed#698
ElderDrivers/EdXposed#699
ElderDrivers/EdXposed#700
ElderDrivers/EdXposed#701
ElderDrivers/EdXposed#702
ElderDrivers/EdXposed#703
ElderDrivers/EdXposed#704
ElderDrivers/EdXposed#705
ElderDrivers/EdXposed#706
ElderDrivers/EdXposed#707
ElderDrivers/EdXposed#708
ElderDrivers/EdXposed#709
ElderDrivers/EdXposed#710
ElderDrivers/EdXposed#711
ElderDrivers/EdXposed#712
ElderDrivers/EdXposed#713
ElderDrivers/EdXposed#714
ElderDrivers/EdXposed#715
ElderDrivers/EdXposed#716
ElderDrivers/EdXposed#717
ElderDrivers/EdXposed#718
ElderDrivers/EdXposed#719
ElderDrivers/EdXposed#720
ElderDrivers/EdXposed#721
ElderDrivers/EdXposed#722
ElderDrivers/EdXposed#723
ElderDrivers/EdXposed#724
ElderDrivers/EdXposed#725
ElderDrivers/EdXposed#726
ElderDrivers/EdXposed#727
ElderDrivers/EdXposed#728
ElderDrivers/EdXposed#729
ElderDrivers/EdXposed#730
ElderDrivers/EdXposed#731
ElderDrivers/EdXposed#732
ElderDrivers/EdXposed#733
ElderDrivers/EdXposed#734
ElderDrivers/EdXposed#735
ElderDrivers/EdXposed#736
ElderDrivers/EdXposed#737
ElderDrivers/EdXposed#738
ElderDrivers/EdXposed#739
ElderDrivers/EdXposed#740
ElderDrivers/EdXposed#741
ElderDrivers/EdXposed#742
ElderDrivers/EdXposed#743
ElderDrivers/EdXposed#744
ElderDrivers/EdXposed#745
ElderDrivers/EdXposed#746
ElderDrivers/EdXposed#747
ElderDrivers/EdXposed#748
ElderDrivers/EdXposed#749
ElderDrivers/EdXposed#750
ElderDrivers/EdXposed#751
ElderDrivers/EdXposed#752
ElderDrivers/EdXposed#753
ElderDrivers/EdXposed#754
ElderDrivers/EdXposed#755
ElderDrivers/EdXposed#756
ElderDrivers/EdXposed#757
ElderDrivers/EdXposed#758
ElderDrivers/EdXposed#759
ElderDrivers/EdXposed#760
ElderDrivers/EdXposed#761
ElderDrivers/EdXposed#762
ElderDrivers/EdXposed#763
ElderDrivers/EdXposed#764
ElderDrivers/EdXposed#765
ElderDrivers/EdXposed#766
ElderDrivers/EdXposed#767
ElderDrivers/EdXposed#768
ElderDrivers/EdXposed#769
ElderDrivers/EdXposed#770
ElderDrivers/EdXposed#771
ElderDrivers/EdXposed#772
ElderDrivers/EdXposed#773
ElderDrivers/EdXposed#774
ElderDrivers/EdXposed#775
ElderDrivers/EdXposed#776
ElderDrivers/EdXposed#777
https://github.com/ElderDrivers/EdXposed/issues/778
ElderDrivers/EdXposed#779
ElderDrivers/EdXposed#780
ElderDrivers/EdXposed#781
ElderDrivers/EdXposed#782
ElderDrivers/EdXposed#783
ElderDrivers/EdXposed#784
ElderDrivers/EdXposed#785
ElderDrivers/EdXposed#786
ElderDrivers/EdXposed#787
ElderDrivers/EdXposed#788
ElderDrivers/EdXposed#789
ElderDrivers/EdXposed#790
ElderDrivers/EdXposed#791
ElderDrivers/EdXposed#792
ElderDrivers/EdXposed#793
ElderDrivers/EdXposed#794
ElderDrivers/EdXposed#795
ElderDrivers/EdXposed#796
ElderDrivers/EdXposed#797
ElderDrivers/EdXposed#798
ElderDrivers/EdXposed#799
ElderDrivers/EdXposed#800
ElderDrivers/EdXposed#801
ElderDrivers/EdXposed#802
ElderDrivers/EdXposed#803
ElderDrivers/EdXposed#804
ElderDrivers/EdXposed#805
ElderDrivers/EdXposed#806
ElderDrivers/EdXposed#807
ElderDrivers/EdXposed#808
ElderDrivers/EdXposed#809
ElderDrivers/EdXposed#810
ElderDrivers/EdXposed#811
ElderDrivers/EdXposed#812
ElderDrivers/EdXposed#813
ElderDrivers/EdXposed#814
ElderDrivers/EdXposed#815
ElderDrivers/EdXposed#816
ElderDrivers/EdXposed#817
ElderDrivers/EdXposed#818
ElderDrivers/EdXposed#819
ElderDrivers/EdXposed#820
ElderDrivers/EdXposed#821
https://github.com/ElderDrivers/EdXposed/issues/822
ElderDrivers/EdXposed#823
ElderDrivers/EdXposed#824
ElderDrivers/EdXposed#825
ElderDrivers/EdXposed#826
ElderDrivers/EdXposed#827
ElderDrivers/EdXposed#828
ElderDrivers/EdXposed#829
ElderDrivers/EdXposed#830
ElderDrivers/EdXposed#831
ElderDrivers/EdXposed#832
ElderDrivers/EdXposed#833
ElderDrivers/EdXposed#834
ElderDrivers/EdXposed#835
ElderDrivers/EdXposed#836
ElderDrivers/EdXposed#837
ElderDrivers/EdXposed#838
ElderDrivers/EdXposed#839
ElderDrivers/EdXposed#840
ElderDrivers/EdXposed#841
ElderDrivers/EdXposed#842
ElderDrivers/EdXposed#843
ElderDrivers/EdXposed#844
ElderDrivers/EdXposed#845
ElderDrivers/EdXposed#846
ElderDrivers/EdXposed#847
ElderDrivers/EdXposed#848
ElderDrivers/EdXposed#849
ElderDrivers/EdXposed#850
ElderDrivers/EdXposed#851
ElderDrivers/EdXposed#852
ElderDrivers/EdXposed#853
ElderDrivers/EdXposed#854
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
wontfix This will not be worked on
Projects
None yet
Development

No branches or pull requests

4 participants