diff options
| author | 2022-11-17 00:45:13 +0000 | |
|---|---|---|
| committer | 2022-11-17 00:45:13 +0000 | |
| commit | 901b2e1a3ae7f4ceea797760aa776f99c9746bbc (patch) | |
| tree | 05549801f12d87b697d458b37e746029f67c99c3 | |
| parent | 7360f8cb025d702df3d13316db3c4bb190941093 (diff) | |
| parent | b1fd297a2a6e46db949b416f6812cd2cdacd27c7 (diff) | |
Merge "libbinder_ndk: more accurate error for array allocator failure" am: b1fd297a2a
Original change: https://android-review.googlesource.com/c/platform/frameworks/native/+/2304973
Change-Id: Ibfa6144d9af41fdc408e5c2b12655e290d644bb8
Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
| -rw-r--r-- | libs/binder/ndk/parcel.cpp | 24 |
1 files changed, 21 insertions, 3 deletions
diff --git a/libs/binder/ndk/parcel.cpp b/libs/binder/ndk/parcel.cpp index c320e8d6df..86930229ce 100644 --- a/libs/binder/ndk/parcel.cpp +++ b/libs/binder/ndk/parcel.cpp @@ -129,7 +129,13 @@ binder_status_t ReadArray(const AParcel* parcel, void* arrayData, } T* array; - if (!allocator(arrayData, length, &array)) return STATUS_NO_MEMORY; + if (!allocator(arrayData, length, &array)) { + if (length < 0) { + return STATUS_UNEXPECTED_NULL; + } else { + return STATUS_NO_MEMORY; + } + } if (length <= 0) return STATUS_OK; if (array == nullptr) return STATUS_NO_MEMORY; @@ -157,7 +163,13 @@ binder_status_t ReadArray<char16_t>(const AParcel* parcel, void* arrayData, } char16_t* array; - if (!allocator(arrayData, length, &array)) return STATUS_NO_MEMORY; + if (!allocator(arrayData, length, &array)) { + if (length < 0) { + return STATUS_UNEXPECTED_NULL; + } else { + return STATUS_NO_MEMORY; + } + } if (length <= 0) return STATUS_OK; if (array == nullptr) return STATUS_NO_MEMORY; @@ -204,7 +216,13 @@ binder_status_t ReadArray(const AParcel* parcel, void* arrayData, ArrayAllocator return status; } - if (!allocator(arrayData, length)) return STATUS_NO_MEMORY; + if (!allocator(arrayData, length)) { + if (length < 0) { + return STATUS_UNEXPECTED_NULL; + } else { + return STATUS_NO_MEMORY; + } + } if (length <= 0) return STATUS_OK; |