X-Git-Url: https://git.zerfleddert.de/cgi-bin/gitweb.cgi/ms2-fixes/blobdiff_plain/ee6322a1851220fd0855348d07cca15e826c6a5e..08fec0be398954b85575af913448efa8a2e34d19:/MS2Debounce/src/de/rmdir/ms2debounce/DebounceModuleHelper.java diff --git a/MS2Debounce/src/de/rmdir/ms2debounce/DebounceModuleHelper.java b/MS2Debounce/src/de/rmdir/ms2debounce/DebounceModuleHelper.java index e4ad296..93fd221 100644 --- a/MS2Debounce/src/de/rmdir/ms2debounce/DebounceModuleHelper.java +++ b/MS2Debounce/src/de/rmdir/ms2debounce/DebounceModuleHelper.java @@ -3,22 +3,29 @@ package de.rmdir.ms2debounce; import java.io.InputStream; import java.io.OutputStream; import java.io.File; +import java.io.FileReader; +import java.io.BufferedReader; import android.content.Context; +import android.content.SharedPreferences; public class DebounceModuleHelper { private Context ctx; + public static final String PREFS_NAME = "DebounceCfg"; public DebounceModuleHelper(Context context) { ctx = context; } public void loadModule() { - loadModule(10); + SharedPreferences settings = ctx.getSharedPreferences(PREFS_NAME, Context.MODE_PRIVATE); + + int delay = settings.getInt("debounce_delay", 10); + loadModule(delay); } - public void loadModule(int delay) { + public synchronized void loadModule(int delay) { File debounce_ko = new File(ctx.getFilesDir() + "/debounce.ko"); extractModule(); @@ -28,22 +35,74 @@ public class DebounceModuleHelper try { Process insmod = Runtime.getRuntime().exec(new String[]{"su","-c","/system/bin/insmod " + debounce_ko + " debounce_delay=" + delay}); insmod.waitFor(); - } catch (Exception e) {} + } catch (Exception e) { + return; + } + + if (getDelay() <= 0) { + return; + } + + /* Module was obviously loaded, so it is safe to load on boot */ + if (!is_safe_to_load()) { + SharedPreferences settings = ctx.getSharedPreferences(PREFS_NAME, Context.MODE_PRIVATE); + SharedPreferences.Editor editor = settings.edit(); + editor.putBoolean("safe_to_load", true); + editor.commit(); + } } - public void unloadModule() { + public synchronized void unloadModule() { try { Process rmmod = Runtime.getRuntime().exec(new String[]{"su","-c","/system/bin/rmmod debounce"}); rmmod.waitFor(); } catch (Exception e) {} } - public boolean isLoaded() { - return false; + public synchronized boolean isLoaded() { + boolean loaded = false; + try { + String read; + + FileReader modules = new FileReader("/proc/modules"); + BufferedReader modules_buf = new BufferedReader(modules); + + while((read = modules_buf.readLine()) != null) { + if (read.regionMatches(0, "debounce", 0, 8)) { + loaded = true; + } + } + + } catch (Exception e) { + loaded = false; + } + + return loaded; + } + + public synchronized int getDelay() { + int debounce_delay = -1; + + try { + String read; + + FileReader delay = new FileReader("/sys/module/debounce/parameters/debounce_delay"); + BufferedReader delay_buf = new BufferedReader(delay); + + read = delay_buf.readLine(); + if (read != null) { + debounce_delay = Integer.parseInt(read.trim()); + } + } catch (Exception e) {} + + return debounce_delay; } - public int getDelay() { - return 10; + public synchronized boolean is_safe_to_load() { + SharedPreferences settings = ctx.getSharedPreferences(PREFS_NAME, Context.MODE_PRIVATE); + boolean safe_to_load = settings.getBoolean("safe_to_load", false); + + return safe_to_load; } private synchronized void extractModule() {