Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Turning off USB charging of the target from the energy meter #118

Open
joelagnel opened this issue May 2, 2017 · 4 comments
Open

Turning off USB charging of the target from the energy meter #118

joelagnel opened this issue May 2, 2017 · 4 comments

Comments

@joelagnel
Copy link

Can we instruct the target to turn off USB charging from the energy meter as a hint?

Currently this has to be done manually either from target.execute or from adb. Can we automate this by providing some per-device abstraction?

CC @bjackman @derkling

@bjackman
Copy link
Contributor

bjackman commented May 3, 2017

AndroidTarget has a property for this: https://github.com/ARM-software/devlib/blob/master/devlib/target.py#L1092

As far as it's been tested, it currently only works on Google Pixel. However if another device has a different method for disabling charging then it should be possible to override the mechanism.

@joelagnel
Copy link
Author

joelagnel commented May 3, 2017

Thanks @bjackman for pointing that out.
Is it Ok if we provide a way to override the path from: libs/utils/platforms/pixel.json ?
Also, since this is related to emeter usage, can we have emeter set this to False during start/reset and set to True after stop? Just want to avoid the possiblity that the user forgets to set it before emeter reset.

@bjackman
Copy link
Contributor

bjackman commented May 4, 2017

Is it Ok if we provide a way to override the path from: libs/utils/platforms/pixel.

Maybe we can do that, but that means adding API surface so it musn't be a hack to solve a problem for a specific platform. How to dis/enable charging is really procedural information rather than data so I'd want to be conservative about designing a JSON interface for it (Even if we assume it's always a case of writing a sysfs file, we need to store the values to write. Do we assume that it's always the same file to enable and disable? Should we read the file back to check it was updated or is it write-only? What if there are multiple power sources to be dis/enabled?).

Also, that configuration isn't technically necessary, the problem could be solved in devlib by making the charging_enabled property implementation more generic - that's what I meant by "it should be possible to override the mechanism."

Also, since this is related to emeter usage, can we have emeter set this to False during start/reset and set to True after stop?

Yeah that sounds sensible, probably libs/utils/energy.py is the place to do that - patches welcome 😁

@joelagnel
Copy link
Author

Turns out charging disable from target side is unreliable on devices. It seems to confuse the host-side, and if the host drops the USB connection, then there isn't any way to re-enable charging because that requires the USB connection to begin with. I think some USB host controllers do monitor VBUS current.

Considering the nature of doing this which platform-specific and the fact that its unreliable, I think we should just use something like USB passthrough where USB automatically disconnected externally by the emeter. I started a discussion here: #121

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants