}
public synchronized boolean _loadModule() throws NotRootedException,ShellException {
- File debounce_ko = new File(ctx.getFilesDir() + "/debounce.ko");
+ File insmod = new File("/system/bin/insmod");
+ if (!insmod.exists()) {
+ insmod = new File("/system/xbin/insmod");
+ if (!insmod.exists()) {
+ return false;
+ }
+ }
- extractModule();
+ File debounce_ko = new File("/system/lib/modules/debounce.ko");
+ if (!debounce_ko.exists()) {
+ debounce_ko = new File(ctx.getFilesDir() + "/debounce.ko");
+
+ extractModule();
+ }
SharedPreferences settings = ctx.getSharedPreferences(PREFS_NAME, Context.MODE_PRIVATE);
SharedPreferences.Editor editor = settings.edit();
editor.commit();
}
- runAsRoot("/system/bin/insmod " + debounce_ko + " || /system/xbin/insmod " + debounce_ko);
+ runAsRoot(insmod + " " + debounce_ko);
+
+ int cnt = 10;
+ while ((!isLoaded()) && (cnt > 0)) {
+ try {
+ Thread.sleep(100);
+ } catch (Exception e) {
+ return false;
+ }
+ cnt--;
+ }
if (!isLoaded()) {
return false;
}
public synchronized void unloadModule() throws NotRootedException,ShellException {
- runAsRoot("/system/bin/rmmod debounce || /system/xbin/rmmod debounce");
+ File rmmod = new File("/system/bin/rmmod");
+
+ if (!rmmod.exists()) {
+ rmmod = new File("/system/xbin/rmmod");
+ if (!rmmod.exists()) {
+ return;
+ }
+ }
+
+ runAsRoot(rmmod + " debounce");
}
public synchronized boolean isLoaded() {
boolean loaded = false;
+
try {
String read;
while((read = modules_buf.readLine()) != null) {
if (read.regionMatches(0, "debounce", 0, 8)) {
- loaded = true;
+ File sysdir = new File("/sys/devices/debounce");
+ if (sysdir.exists() && sysdir.isDirectory()) {
+ loaded = true;
+ break;
+ }
}
}
-
} catch (Exception e) {
loaded = false;
}