[APP] DHD Proximity Sensor Recalibrator 1.10 (26-Sep-12)

Search This thread

leppie

Senior Member
Dec 21, 2008
566
284
Cape Town
Due to many DHD's being incorrectly factory calibrated with regards to the proximity sensor, I wrote a little app to allow one to change the calibration on-the-fly and persist it over reboots.

This app is specifically for those experience issues with the proximity sensor.

Well known symptoms include the following:

- Screen fails to turn off when holding to face on a call
- Screen does turn off when holding to face on a call, but fails to come back on, requiring taking out the battery

These problems are common in custom kernels/ROM's. HTC has addressed this issue however in their kernels from 1.32 onwards, but have failed to provide an acceptable solution for some.

I present DHD Proximity Sensor Recalibrator. Download from the attachments below.

Here are some screenshots:

attachment.php
attachment.php


attachment.php


Usage:

1. Install app.
2. Run app.
3. Press the toggle button to start monitoring.
4. Move your finger over the proximity sensor (the little LED next to the front facing speaker).
5. Adjust the High and Low threshold values to your liking.

For those whose screen does not turn off, it probably means the factory values are set too high.

For those whose screen does not turn back on, it probably means the factory values are set too low.

The setting will be saved, and will be applied every time you reboot your phone. No need to go through any of the steps unless you want to change the calibration. When the settings are applied at boot time, you will get a toasty indicating the calibration value applied.

Possible calibration procedure:

1. Put both values high (will show FAR).
2. Cover sensor with finger.
3. Lower High threshold till it says NEAR.
4. Lower Low threshold by a notch or 2.
5. Test behavior

Removal:

If for whatever reason you find the application does not work, or you do not want it anymore, just uninstall the app, and reboot. Your original factory settings will be in effect again. This application does not modify your system. It might require root rights.

Source code repo:

https://github.com/leppie/DHD-Proximity-Sensor-Recalibrator

Known issues:

- Permissions have changed in CM7 RC2, preventing the application from working correctly. The application will need root. Will investigate how to add that, if needed.

- Some reports that the Gingerbread leaked ROM is not working.

Gingerbread/newer kernel update:

Due to changes in the source code made by HTC to overcome this issue in the kernel, this app will probably not run correctly.

There are 2 problems (as found from latest CM kernel source):

1. When the kernel recalibrates the proximity on the fly, it fails to update the internal structures in the kernel. This makes the kernel not report correct values. I have made a kernel patch to rectify the issue. Please ask your kernel developer to apply the following changes: https://github.com/leppie/htc-kernel-msm7x30/commit/b1d0a85f3fe5252c8ab43ba98261bcb1b8498d8a

2. Secondly and more seriously, depending on the initial calibrated value (if LT is greater or equal to 0x50), the kernel will kick off a polling thread. This will overwrite the changes made by this app, as soon as you use the proximity sensor for the first time (eg the phone). Afterwards you can apply the values from this app again, and from my experiments the value sticks then (up to the next reboot). Unfortunately, this polling mechanism fixes the issue for most users, so it cannot just be disabled. It is easy to disable in the kernel source however, but will probably break most other people's proximity behavior if they do not have this app installed. As you can see, there is not much I can do about this. The best option is to compile your own kernel.

Manual cleaning of the sensor:

After time the sensor will become dirty from the environment. See http://forum.xda-developers.com/showpost.php?p=28495941&postcount=357 for details on cleaning it.

Please report any bug and suggestions.

Cheers ;)

Revisions:

1.0

- Initial public release

1.1

- Replaced toggle button with normal one to resolve known issue

1.2

- Removed amount from Paypal, feel free to donate whatever you feel like. Beers are around US$2 here.

1.3

- Add some better handling when something goes not as planned (likely on non-DHD hardware).

1.4

- Added some alert dialogs to aid with the problems people are experiencing. (In case of error, please note both the title text, and the first few lines in the text of the alert dialog.)

1.5

- Only for CM7 users. Use nightly 92 or above. This includes the necessary kernel patch.
- Should work on SENSE with custom kernel. Apply this patch (or ask your kernel 'builder' to do so).
- Removed Beer button due to crappy paypal policy...

1.6

- Added support for calling 'su' when permissions are wrong. Thanks VampireWicked.

1.7

- Correct boot permissions for ICS

1.8

- Prevent app from being installed on SD card (which will cause issues) (thanks makarand14)

1.9

- Fix issues with sensor listener not getting disabled (thanks Roberto_Lim and Stoffl_)

1.10

- Fix issues with slow process manager in Android, notably in BlackOut ROM (thanks tonylee000 and others)

Supported kernels:

- CM7 nightly #92 or later
- LorDModUE V2.6 or later
 

Attachments

  • ps_polling_ignore.diff.txt
    1.4 KB · Views: 10,639
Last edited:

Stuclint

Senior Member
Nov 14, 2006
59
1
Berlin
Awesome!

This is my favorite app to date! I couldn't use any Cyanogen mod because of this issue. (My device was not waking up after the first phone call) Everything else worked fine.

Now I can use my phone as a phone too!

Would recommend to any O2 Germany DHD user having similar issues. :D
 
  • Like
Reactions: leppie

Pwoap

New member
Jan 26, 2011
2
0
This is my favorite app to date! I couldn't use any Cyanogen mod because of this issue. (My device was not waking up after the first phone call) Everything else worked fine.

Now I can use my phone as a phone too!

Would recommend to any O2 Germany DHD user having similar issues. :D

Yep i'm O2 Germany DHD user too and had this issue.
This is really a life-saver app, thanks!
You are awesome, leppie!
 

winwintoto1234

Senior Member
Jan 2, 2011
304
9
KK, Sabah
I had this sensor problem and did make enquiry in other thread but can't find anysolution.
However, (don't konw since when) it works without any problem now.
Guess I should subscribe this thread just in case I need it in future (hopefully not).:D
Thanks leppie!
5 stars rated.
 
Last edited:

madindehead

Senior Member
Apr 14, 2009
2,292
81
Ace app! Even though I'm on stock, I sometimes get problems with my screen coming on during a call, and my accidentally muting the call. This should help me fix it, by fixing the threshold distance!

Awesome, thanks :)
 

djuri147

New member
Feb 16, 2011
1
0
hi,

i have both sensor problems! every second time my phone turns off the screen while phoning but not on again or somtimes the sreen is still on while phoneing

with the app i can set the sensor but still not working during a call

can someone help me?

sry for my bad english
 

Top Liked Posts

  • There are no posts matching your filters.
  • 155
    Due to many DHD's being incorrectly factory calibrated with regards to the proximity sensor, I wrote a little app to allow one to change the calibration on-the-fly and persist it over reboots.

    This app is specifically for those experience issues with the proximity sensor.

    Well known symptoms include the following:

    - Screen fails to turn off when holding to face on a call
    - Screen does turn off when holding to face on a call, but fails to come back on, requiring taking out the battery

    These problems are common in custom kernels/ROM's. HTC has addressed this issue however in their kernels from 1.32 onwards, but have failed to provide an acceptable solution for some.

    I present DHD Proximity Sensor Recalibrator. Download from the attachments below.

    Here are some screenshots:

    attachment.php
    attachment.php


    attachment.php


    Usage:

    1. Install app.
    2. Run app.
    3. Press the toggle button to start monitoring.
    4. Move your finger over the proximity sensor (the little LED next to the front facing speaker).
    5. Adjust the High and Low threshold values to your liking.

    For those whose screen does not turn off, it probably means the factory values are set too high.

    For those whose screen does not turn back on, it probably means the factory values are set too low.

    The setting will be saved, and will be applied every time you reboot your phone. No need to go through any of the steps unless you want to change the calibration. When the settings are applied at boot time, you will get a toasty indicating the calibration value applied.

    Possible calibration procedure:

    1. Put both values high (will show FAR).
    2. Cover sensor with finger.
    3. Lower High threshold till it says NEAR.
    4. Lower Low threshold by a notch or 2.
    5. Test behavior

    Removal:

    If for whatever reason you find the application does not work, or you do not want it anymore, just uninstall the app, and reboot. Your original factory settings will be in effect again. This application does not modify your system. It might require root rights.

    Source code repo:

    https://github.com/leppie/DHD-Proximity-Sensor-Recalibrator

    Known issues:

    - Permissions have changed in CM7 RC2, preventing the application from working correctly. The application will need root. Will investigate how to add that, if needed.

    - Some reports that the Gingerbread leaked ROM is not working.

    Gingerbread/newer kernel update:

    Due to changes in the source code made by HTC to overcome this issue in the kernel, this app will probably not run correctly.

    There are 2 problems (as found from latest CM kernel source):

    1. When the kernel recalibrates the proximity on the fly, it fails to update the internal structures in the kernel. This makes the kernel not report correct values. I have made a kernel patch to rectify the issue. Please ask your kernel developer to apply the following changes: https://github.com/leppie/htc-kernel-msm7x30/commit/b1d0a85f3fe5252c8ab43ba98261bcb1b8498d8a

    2. Secondly and more seriously, depending on the initial calibrated value (if LT is greater or equal to 0x50), the kernel will kick off a polling thread. This will overwrite the changes made by this app, as soon as you use the proximity sensor for the first time (eg the phone). Afterwards you can apply the values from this app again, and from my experiments the value sticks then (up to the next reboot). Unfortunately, this polling mechanism fixes the issue for most users, so it cannot just be disabled. It is easy to disable in the kernel source however, but will probably break most other people's proximity behavior if they do not have this app installed. As you can see, there is not much I can do about this. The best option is to compile your own kernel.

    Manual cleaning of the sensor:

    After time the sensor will become dirty from the environment. See http://forum.xda-developers.com/showpost.php?p=28495941&postcount=357 for details on cleaning it.

    Please report any bug and suggestions.

    Cheers ;)

    Revisions:

    1.0

    - Initial public release

    1.1

    - Replaced toggle button with normal one to resolve known issue

    1.2

    - Removed amount from Paypal, feel free to donate whatever you feel like. Beers are around US$2 here.

    1.3

    - Add some better handling when something goes not as planned (likely on non-DHD hardware).

    1.4

    - Added some alert dialogs to aid with the problems people are experiencing. (In case of error, please note both the title text, and the first few lines in the text of the alert dialog.)

    1.5

    - Only for CM7 users. Use nightly 92 or above. This includes the necessary kernel patch.
    - Should work on SENSE with custom kernel. Apply this patch (or ask your kernel 'builder' to do so).
    - Removed Beer button due to crappy paypal policy...

    1.6

    - Added support for calling 'su' when permissions are wrong. Thanks VampireWicked.

    1.7

    - Correct boot permissions for ICS

    1.8

    - Prevent app from being installed on SD card (which will cause issues) (thanks makarand14)

    1.9

    - Fix issues with sensor listener not getting disabled (thanks Roberto_Lim and Stoffl_)

    1.10

    - Fix issues with slow process manager in Android, notably in BlackOut ROM (thanks tonylee000 and others)

    Supported kernels:

    - CM7 nightly #92 or later
    - LorDModUE V2.6 or later
    5
    I fixed it! I started having problems a while back. The screen didn't turn off when I was in a phone call. It got worse and worse until I had the settings down to 5/6.

    The kernel I have is not fully supported, so after each reboot I had to start the program 2 times to get it to work.

    I took the phone apart - How to here: http://www.youtube.com/watch?v=2Zc0k994Pl4

    Do everything until 2:27. Clean the proximity sensor and the surrounding areas and put it back together. It works like new now :)

    I also did the GPS fix by connecting a wire between the antenna contacts inside the LED cover. 10 satellites now!
    4
    new version. ICS support.
    3
    Sorry, it has nothing to do with your app. Its the fault of the kernel not supporting your app (which support should be built in - a no brainer).

    ARHD 6.3.3 RCMix Kernel - Cannot write on autostart
    ARHD 6.3.3 Lord's Kernel - Works Great
    Virtuous Infinity - Cannot write on autostart
    Blackout ICS - Cannot write on autostart
    Ice Cold Sandwich - Works Great
    JellyTime - - Works Great

    I can post a screenie... but its really a kernel issue.

    It's not a kernel issue. It's a permissions issue. I had it working fine on blackout but had the cannot write problem. use root explorer to change the permissions for the file //sys/devices/virtual/optical_sensors/proximity/ps_kadc and tick all the read and write boxes.

    Hope this helps.
    3
    New version out. See OP.

    There were 2 issues:

    1. Big oopsie by me, I never fixed the permissions when applying values on a reboot. Thanks all for making this clear :D

    2. The android process manager does seem to take a while to load so the broadcast receiver was timing out (10 second limit). Had to add a service now, that will deal with this delay, and quit when done.
Our Apps
Get our official app!
The best way to access XDA on your phone
Nav Gestures
Add swipe gestures to any Android
One Handed Mode
Eases uses one hand with your phone