diff options
author | Vladimir Chtchetkine <vchtchetkine@google.com> | 2011-08-12 14:03:40 -0700 |
---|---|---|
committer | Android Code Review <code-review@android.com> | 2011-08-12 14:03:40 -0700 |
commit | 6cb2c5af3d3d23d35072beae0edb3614e2c3deb8 (patch) | |
tree | 9830cc6d9f665bc80f884166ac01dcc337ada94f /android | |
parent | ae65ddf1457ee22a81849ae5e0b9e17868cd2deb (diff) | |
parent | 5297e197c131258f3b115d1fc4ab608224b39bb9 (diff) | |
download | external_qemu-6cb2c5af3d3d23d35072beae0edb3614e2c3deb8.zip external_qemu-6cb2c5af3d3d23d35072beae0edb3614e2c3deb8.tar.gz external_qemu-6cb2c5af3d3d23d35072beae0edb3614e2c3deb8.tar.bz2 |
Merge "Fix fron report on unexpected qemud char channel close."
Diffstat (limited to 'android')
-rw-r--r-- | android/hw-qemud.c | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/android/hw-qemud.c b/android/hw-qemud.c index 9bfeaff..7020723 100644 --- a/android/hw-qemud.c +++ b/android/hw-qemud.c @@ -2124,8 +2124,22 @@ _qemud_char_client_recv( void* opaque, uint8_t* msg, int msglen, */ static void _qemud_char_client_close( void* opaque ) + { - derror("unexpected qemud char. channel close"); + QemudClient* client = opaque; + + /* At this point modem driver still uses char pipe to communicate with + * hw-qemud, while communication with the guest is done over qemu pipe. + * So, when guest disconnects from the qemu pipe, and emulator-side client + * goes through the disconnection process, this routine is called, since it + * has been set to called during service registration. Unless modem driver + * is changed to drop char pipe communication, this routine will be called + * due to guest disconnection. As long as the client was a qemu pipe - based + * client, it's fine, since we don't really need to do anything in this case. + */ + if (!_is_pipe_client(client)) { + derror("unexpected qemud char. channel close"); + } } |