diff options
author | 2009-02-13 16:34:38 -0800 | |
---|---|---|
committer | 2009-02-13 16:34:38 -0800 | |
commit | bc4afde167513f7efe76012015f9fa3641c156cf (patch) | |
tree | 6160c4da2cf96d3aa12354b8ece2fcfc24d22b12 | |
parent | eef3c54deb1cb66455ae385075333f163e5fb838 (diff) |
Need to dup file descriptor when reading from the binder for native handles
When reading a native handle that has passed through the binder,
the fds have to be duped to prevent them from getting closed when the binder
object is destructed.
Signed-off-by: Rebecca Schultz Zavin <rebecca@android.com>
-rw-r--r-- | libs/utils/Parcel.cpp | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/libs/utils/Parcel.cpp b/libs/utils/Parcel.cpp index 0eba0b07c8d4..2962b25aeae2 100644 --- a/libs/utils/Parcel.cpp +++ b/libs/utils/Parcel.cpp @@ -945,14 +945,13 @@ native_handle* Parcel::readNativeHandle(native_handle* (*alloc)(void*, int, int) return 0; } } - for (int i=0 ; err==NO_ERROR && i<numFds ; i++) { - h->data[i] = readFileDescriptor(); + h->data[i] = dup(readFileDescriptor()); if (h->data[i] < 0) err = BAD_VALUE; } - + err = read(h->data + numFds, sizeof(int)*numInts); - + if (err != NO_ERROR) { if (alloc == 0) { free(h); |