-
Notifications
You must be signed in to change notification settings - Fork 912
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
Androids dreaming of stormy weather #3484
Comments
Nice, i.e. i did once run c/ln compiled in termux on the phone from old source source that i patched step by step to reach master side by side with a full node over orbot tor proxy, stopped this effort a year or so. |
I think that since I've started working on moving our Bitcoin backend to plugins, I've started dreaming of having C-lightning + a Bitcoin plugin hitting my esplora API englobed in a Kivy Android app 😁. |
Is it really c-lightning's power consumption or is it the co-located |
Sure more bitcoind! And c-lightning is rather lightweight, but can we ever see soverain trustless private pseudonymous LN and make up for the sins of NAT, without a full node? And will it not be in the near future, that LN is integral part of a matching core node? In general SW dev in my view should not only in sight of global warming have an eye on power consumption, every byte touched or moved is one byte to much. ̶E̶D̶I̶T̶:̶ ̶S̶h̶o̶r̶t̶ ̶s̶i̶d̶e̶ ̶n̶o̶t̶e̶,̶ ̶c̶o̶l̶o̶s̶s̶u̶s̶ ̶h̶t̶t̶p̶s̶:̶/̶/̶t̶w̶i̶t̶t̶e̶r̶.̶c̶o̶m̶/̶s̶c̶i̶e̶n̶c̶e̶m̶u̶s̶e̶u̶m̶/̶s̶t̶a̶t̶u̶s̶/̶1̶2̶2̶5̶0̶2̶1̶4̶8̶7̶1̶2̶1̶3̶3̶8̶3̶7̶0̶ ̶w̶a̶s̶ ̶a̶l̶l̶e̶g̶e̶d̶l̶y̶ ̶u̶s̶e̶d̶ ̶t̶o̶d̶a̶y̶ ̶i̶n̶ ̶4̶4̶ ̶f̶o̶r̶ ̶t̶h̶e̶ ̶1̶s̶t̶ ̶t̶i̶m̶e̶,̶ ̶w̶e̶ ̶s̶h̶o̶u̶l̶d̶ ̶h̶a̶v̶e̶ ̶a̶l̶s̶o̶ ̶a̶n̶ ̶o̶p̶e̶n̶ ̶e̶y̶e̶ ̶o̶n̶ ̶N̶u̶m̶b̶e̶r̶W̶a̶n̶g̶,̶ ̶s̶o̶ ̶s̶o̶m̶e̶t̶i̶m̶e̶s̶ ̶m̶o̶r̶e̶ ̶m̶a̶g̶i̶c̶ ̶b̶y̶t̶e̶s̶ ̶a̶r̶e̶ ̶g̶o̶o̶d̶.̶ |
I'm going to close #3473 because I can now build and run clightning on my android phone using the bitcoin_ndk project referenced in greenaddress/bitcoin_ndk#21. My setup: MacOS Catalina 10.15.2 (Macbook Pro, 8GB RAM, 128GB HD)
Note: For MacOS you need to create symlinks to sha256sum so the final report at step 7 works, but it does not prevent creation of the executable artifacts. (MacOS guide)
You should expect to get back: "v0.7.3-modded" I did some preliminary testing with a lightning config file on my phone which accesses a regtest bitcoind on my host machine. The bitcoin.conf on my host machine allows RPC access to connections on my local network:
I tested it like this:
Many thanks to @lvaccaro, the bitcoin-ndk team and everyone else who has helped make cross-compiling clightning for android possible, and now even easier to do. |
Thanks for sharing @cdecker :-) I really like add a CI for cross-compilation (github or gitlab) but this requires a bit more effort to run configurator as just explain. I'll try to keep in touch :-) |
Great, I will sync the latest changes. It is really helpful to have your build scripts so I can build with some small modifications to c-lightning we are using to test making channel updates over mesh radio. |
I did some pioneering work on this 2 years ago so I'd like to chime in.
In my experience the stumbling blocks are at runtime. c-lightning used to Since Android Q use of Sorry for being a downer. 😢 |
There are lots of painful downside( as described also in porting bitcoin core on android see Abcore project) due to exec, fork, but also background handling. Moreover classic unix socket doesn't work and it needs to use network socket or abstract namespace socket instead. I think that cross-compiling for Android is a good feature and in the future and a prototyping app could be happily announced. Maybe this will not be the final step, but an initial step to study better mobile integration. |
Ouch. We use Unix sockets because Unix sockets are magical and can transport file descriptors across processes (via ancillary data), and we pass fds around a lot between daemons. If that "doesn't work" then that is as much of a problem as running C-Lightning on Windows: #1628 (comment) |
Admittedly there is an API for fd passing on Windows, it's just a bit more convoluted than with Unix sockets. I'm still convinced that given enough time to write a shim we can run on Windows without any architectural changes. Sadly the same cannot be said if future Android versions start restricting |
Thanks for the links and review of the situation @icota. To summarize, it sounds like exec() and fork() will run on currently allowed Android APIs but that there is no guarantees that long running exec/fork processes will not be killed off randomly by the phone OS. That it works at all is something that will be phased out in Android and is already disallowed in iOS. From what I understand, the proper way to manage process lifecycles on mobile is to access native code as a library via JNI or equivalent and manage daemons as service processes. Creating a monolithic target as @cdecker describes is one approach, but I wonder if there isn't a way to keep the independent daemon model, but replace exec/fork to instead use a system compatible with the the Android and iOS process lifecycle model. Perhaps this is too simplistic, but I would want to see if instead of exec() and fork() we can create Android service processes for lightningd and it's daemons. Each service would run the main() entry point in a thread. When prompted by the Android lifecycle system, the service process would make JNI calls to cleanly shutdown or restart each native service/process. |
Depends on how heavyweight an Andriod service is. We launch a process for each channel, and for major state changes of the channel (e.g. transiioning from "negotiating a new channel with peer" to "normal channel operation", or transitioning from "normal operation" to "negotiating the mutual close feerate", for example) we stop one process and then start a replacement to handle the channel. This is fine in GNU/Linux since processes are as lightweight as threads (threads are processes in GNU/Linux, that happen to have shared virtual memory mappings of the same parts of the swapfile). If Android services are heavier, then we would be operating against the grain. |
FWIW I was also able to build and run C-lightning for my non rooted Android phone.
I'm now trying to port @lvaccaro 's patches to v0.8.1(rc3) but there are still a few quirks.. Update: I could succesfully build the freshly released v0.8.1 for
If you want to build for another architecture, change the |
RE: using an Android service vs. Linux thread, I think a key question is if it makes sense architecturally in clightning to abstract the fork() call currently used to launch subdaemons. How hairy would it be to use a JNI callback to launch subprocesses in an Android friendly way? Perhaps it is cleaner (and more lightweight) to spawn threads as @cdecker suggested. |
There have been a couple of attempts to get c-lightning running on Android devices, and I thought it might be a good idea to pull experiences together to see what can be done to make Android support a possibility and make the process of getting it running on Android simpler.
I know that the abcore team (@greenaddress and @lvaccaro) has done some preliminary work to get c-lightning to compile on Android (greenaddress/bitcoin_ndk#21). The approach they followed is:
config.vars
andgen_header_versions.h
on device, since theconfigurator
runs on the compiler hostlightningd
usingclang
for the target archIdeally we'd backport the patches they needed to apply in order to internalize that part. @NickeZ on the other hand has been tackling the need to pre-generate the target
config.vars
andgen_header_versions.h
files in #3464. That'd allow us to compile theconfigurator
for the target arch and run it using the QEMU wrapper. Hopefully that eliminates the need for pre-canned "generated files".Finally @remyers is also working on getting Android support working, with a host
configurator
but otherwise cross-compiling for ARM: #3473Ideally we'd pool our collective experiences in getting the cross-compiled flow working, and document it for others to find in future.
What do you guys think? Are there any stumbling stones that I am missing? Could this allow us to cross-compile reproducible builds as well?
The text was updated successfully, but these errors were encountered: