Issue
I am trying to get mono for android (aka monodroid) working within a windows 7 virtual machine on virtualbox but I am having issues with the adb connection to my phone. When I run "adb devices" to list the devices present it show up no problem, but when I attempt to run an "adb install", logcat, or push it hangs. Currently there is a bug in virtualbox which applies to this but I was hoping someone more knowledgeable than myself would have a workaround.
https://www.virtualbox.org/ticket/6620
Of coarse non of this would be an issue if Xamarin released a linux port of their product or if I got familiar with Java, but I suppose those are slightly different issues.
Solution
Brian, one workaround you might consider is to make your VM host an ADB host as well. Then you can just connect your VM client to it over TCP / IP. Here's the general idea for that setup:
- Install the Android SDK on the host machine. You should only require the platform-tools package which includes
adb
. - Don't allow your VM client to take ownership of the Android device, so disable any VirtualBox USB filter rules you have and it also wouldn't hurt to then detach and reattach the device.
- From your VM client, run
adb kill-server
. Make it atskill adb
for certainty. If you have any running instances of Eclipse, you'll want to shut those down first because it'll actually launchadb
in the background. Don't skip this step. From the host, execute
adb devices
. If all goes well (and it should), you'll see your device listed. It should look something like this (note the port number and sorry for the mangling):* daemon not running. starting it now on port 5037 * * daemon started successfully * List of devices attached 015d2994ed200409 device
At this point, your host should have an ADB server running at port 5037. You can check this from the VM client by running telnet 10.0.2.2 5037
, where 10.0.2.2
is the default IP for VirtualBox hosts and 5037
is the default ADB port noted above.
Now you must either forward the ports from your host to your VM client, or otherwise connect ADB directly to your host IP:port. If you're like me, you'll find the ADBHOST and ANDROID_ADB_SERVER_PORT variables to be poorly documented and easy to screw up. For this reason, consider simple port fowarding over
ssh
(maybe via Cygwin) like so from the VM client:autossh -nNL5037:localhost:5037 -oExitOnForwardFailure=yes 10.0.2.2
Finally, run
adb devices
from your VM client. If you see "daemon not running," it means your port fowarding is screwed up. Otherwise you should see your device and be able to logcat all day. One noteworthy point is that you won't have anadb
daemon running on your VM client, except for when you're actually using the debug bridge, of course.
I've used a similar mechanism for debugging devices over the network that are connected to remote machines and it worked well.
Answered By - Stephen Niedzielski
0 comments:
Post a Comment
Note: Only a member of this blog may post a comment.