X-Git-Url: https://git.zerfleddert.de/cgi-bin/gitweb.cgi/ms2-fixes/blobdiff_plain/c305346095aed12c23e79aee46c0d142e3eb35d8..0b9d6422126cbd641917c648172f890e2ca72c6f:/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 39a29a8..5e2a476 100644 --- a/MS2Debounce/src/de/rmdir/ms2debounce/DebounceModuleHelper.java +++ b/MS2Debounce/src/de/rmdir/ms2debounce/DebounceModuleHelper.java @@ -4,7 +4,10 @@ import java.io.InputStream; import java.io.OutputStream; import java.io.File; import java.io.FileReader; +import java.io.FileWriter; import java.io.BufferedReader; +import java.io.BufferedWriter; +import java.io.DataOutputStream; import android.content.Context; import android.content.SharedPreferences; @@ -13,16 +16,29 @@ public class DebounceModuleHelper { private Context ctx; public static final String PREFS_NAME = "DebounceCfg"; + final int SUPERUSER_REQUEST = 4223; public DebounceModuleHelper(Context context) { ctx = context; } public void loadModule() { - loadModule(getSavedDelay()); + _loadModule(); + setDelay(getSavedDelay()); } - public synchronized void loadModule(int delay) { + protected void runAsRoot(String command) throws java.io.IOException,java.lang.InterruptedException { + Process rootcmd = Runtime.getRuntime().exec(new String[]{"su","-c","sh"}); + DataOutputStream sh = new DataOutputStream(rootcmd.getOutputStream()); + sh.writeBytes(command + "\n"); + sh.writeBytes("exit\n"); + sh.flush(); + sh.close(); + + rootcmd.waitFor(); + } + + public synchronized void _loadModule() { File debounce_ko = new File(ctx.getFilesDir() + "/debounce.ko"); extractModule(); @@ -35,8 +51,7 @@ public class DebounceModuleHelper } try { - Process insmod = Runtime.getRuntime().exec(new String[]{"su","-c","/system/bin/insmod " + debounce_ko + " debounce_delay=" + delay}); - insmod.waitFor(); + runAsRoot("/system/bin/insmod " + debounce_ko); } catch (Exception e) { return; } @@ -45,7 +60,7 @@ public class DebounceModuleHelper return; } - if (getDelay() <= 0) { + if (getDelay() < 0) { return; } @@ -56,8 +71,7 @@ public class DebounceModuleHelper public synchronized void unloadModule() { try { - Process rmmod = Runtime.getRuntime().exec(new String[]{"su","-c","/system/bin/rmmod debounce"}); - rmmod.waitFor(); + runAsRoot("/system/bin/rmmod debounce"); } catch (Exception e) {} } @@ -88,34 +102,39 @@ public class DebounceModuleHelper try { String read; - FileReader delay = new FileReader("/sys/module/debounce/parameters/debounce_delay"); + FileReader delay = new FileReader("/sys/devices/debounce/debounce_delay"); BufferedReader delay_buf = new BufferedReader(delay); read = delay_buf.readLine(); if (read != null) { debounce_delay = Integer.parseInt(read.trim()); } + + delay_buf.close(); } catch (Exception e) {} return debounce_delay; } - public synchronized void setDelay(int delay) { - if (isLoaded()) { - if (getDelay() == delay) { - return; - } - - unloadModule(); + public synchronized void setDelay(int debounce_delay) { + if (!isLoaded()) { + return; } - loadModule(delay); + try { + FileWriter delay = new FileWriter("/sys/devices/debounce/debounce_delay"); + BufferedWriter delay_buf = new BufferedWriter(delay); + + delay_buf.write((new Integer(debounce_delay)).toString()); + + delay_buf.close(); + } catch (Exception e) {} } public synchronized int getSavedDelay() { SharedPreferences settings = ctx.getSharedPreferences(PREFS_NAME, Context.MODE_PRIVATE); - return settings.getInt("debounce_delay", 10); + return settings.getInt("debounce_delay", 8); } public synchronized void setSavedDelay(int delay) {