X-Git-Url: http://git.zerfleddert.de/cgi-bin/gitweb.cgi/ms2-fixes/blobdiff_plain/a7c1cd77598c83fe14577cb0393e76ee7d29645c..b750f7cc72531d334cb93b92448768f846839d23:/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 b5310d6..fbcc837 100644 --- a/MS2Debounce/src/de/rmdir/ms2debounce/DebounceModuleHelper.java +++ b/MS2Debounce/src/de/rmdir/ms2debounce/DebounceModuleHelper.java @@ -32,7 +32,7 @@ public class DebounceModuleHelper setActiveHigh(getSavedActiveHigh()); } - public boolean loadModule() { + public boolean loadModule() throws NotRootedException,ShellException { if (!_loadModule()) return false; @@ -41,21 +41,48 @@ public class DebounceModuleHelper return true; } - 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(); + protected void runAsRoot(String command) throws NotRootedException,ShellException { + Process rootcmd; - rootcmd.waitFor(); + try { + rootcmd = Runtime.getRuntime().exec(new String[]{"su","-c","sh"}); + } catch (java.io.IOException e) { + throw new NotRootedException(); + } + + try { + DataOutputStream sh = new DataOutputStream(rootcmd.getOutputStream()); + sh.writeBytes(command + "\n"); + sh.writeBytes("exit\n"); + sh.flush(); + sh.close(); + } catch (java.io.IOException e) { + throw new ShellException(); + } + + try { + if (rootcmd.waitFor() != 0) + throw new ShellException(); + } catch (java.lang.InterruptedException e) { + throw new ShellException(); + } } - public synchronized boolean _loadModule() { - File debounce_ko = new File(ctx.getFilesDir() + "/debounce.ko"); + public synchronized boolean _loadModule() throws NotRootedException,ShellException { + File insmod = new File("/system/bin/insmod"); + if (!insmod.exists()) { + insmod = new File("/system/xbin/insmod"); + if (!insmod.exists()) { + return false; + } + } + + File debounce_ko = new File("/system/lib/modules/debounce.ko"); + if (!debounce_ko.exists()) { + debounce_ko = new File(ctx.getFilesDir() + "/debounce.ko"); - extractModule(); + extractModule(); + } SharedPreferences settings = ctx.getSharedPreferences(PREFS_NAME, Context.MODE_PRIVATE); SharedPreferences.Editor editor = settings.edit(); @@ -64,11 +91,7 @@ public class DebounceModuleHelper editor.commit(); } - try { - runAsRoot("/system/bin/insmod " + debounce_ko + " || /system/xbin/insmod " + debounce_ko); - } catch (Exception e) { - return false; - } + runAsRoot(insmod + " " + debounce_ko); if (!isLoaded()) { return false; @@ -85,14 +108,17 @@ public class DebounceModuleHelper return true; } - public synchronized boolean unloadModule() { - try { - runAsRoot("/system/bin/rmmod debounce || /system/xbin/rmmod debounce"); - } catch (Exception e) { - return false; + public synchronized void unloadModule() throws NotRootedException,ShellException { + File rmmod = new File("/system/bin/rmmod"); + + if (!rmmod.exists()) { + rmmod = new File("/system/xbin/rmmod"); + if (!rmmod.exists()) { + return; + } } - return true; + runAsRoot(rmmod + " debounce"); } public synchronized boolean isLoaded() { @@ -148,8 +174,7 @@ public class DebounceModuleHelper fbuf.write((new Integer(value)).toString()); fbuf.close(); - } catch (Exception e) { - } + } catch (Exception e) {} } public synchronized int getDelay() {