mirror of
https://github.com/Divested-Mobile/DivestOS-Build.git
synced 2025-01-07 05:37:56 -05:00
59bf3b75c7
https://review.lineageos.org/c/LineageOS/android_frameworks_base/+/353117 https://review.lineageos.org/q/topic:Q_asb_2023-03 https://review.lineageos.org/q/topic:Q_asb_2023-04 https://review.lineageos.org/q/topic:Q_asb_2023-05 https://review.lineageos.org/q/topic:Q_asb_2023-06 https://review.lineageos.org/q/topic:Q_asb_2023-07 https://review.lineageos.org/q/topic:Q_asb_2023-08 accounted for via patches: https://review.lineageos.org/c/LineageOS/android_system_ca-certificates/+/376560 https://review.lineageos.org/c/LineageOS/android_system_ca-certificates/+/376561 https://review.lineageos.org/c/LineageOS/android_system_ca-certificates/+/376562 https://review.lineageos.org/q/topic:Q_asb_2023-09 https://review.lineageos.org/q/topic:Q_asb_2023-10 https://review.lineageos.org/q/topic:Q_asb_2023-11 accounted for via patches: https://review.lineageos.org/c/LineageOS/android_system_ca-certificates/+/376563 accounted for via manifest change: https://review.lineageos.org/c/LineageOS/android_external_webp/+/376568 https://review.lineageos.org/q/topic:Q_asb_2023-12 https://review.lineageos.org/q/topic:Q_asb_2024-01 https://review.lineageos.org/q/topic:Q_asb_2024-02 https://review.lineageos.org/q/topic:Q_asb_2024-03 Signed-off-by: Tavi <tavi@divested.dev>
64 lines
2.9 KiB
Diff
64 lines
2.9 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: Pawan Wagh <waghpawan@google.com>
|
|
Date: Tue, 13 Jun 2023 17:37:26 +0000
|
|
Subject: [PATCH] Use readUniqueFileDescriptor in incidentd service
|
|
|
|
readFileDescriptor doesn't provide ownership of the fds. fdopen
|
|
needs ownership of the fds. Fds read from parcel should be duped
|
|
in this scenario and readUniqueFileDescriptor dups fds internally.
|
|
|
|
Test: m incidentd_service_fuzzer && adb sync data && adb shell /data/fuzz/x86_64/incidentd_service_fuzzer/incidentd_service_fuzzer
|
|
Test: atest incidentd_test
|
|
Bug: 286931110
|
|
Bug: 283699145
|
|
(cherry picked from commit ba78ef276951269f7b024baebdf1b8fa40bedb23)
|
|
(cherry picked from https://googleplex-android-review.googlesource.com/q/commit:b4aaf180ee8f3e375c7ab411f03cf9c24c1d8055)
|
|
Merged-In: Ibe03a17dee91ac5bf25d123d4fd9c0bdd3c7d80e
|
|
Change-Id: Ibe03a17dee91ac5bf25d123d4fd9c0bdd3c7d80e
|
|
---
|
|
cmds/incidentd/src/IncidentService.cpp | 20 ++++++++++++--------
|
|
1 file changed, 12 insertions(+), 8 deletions(-)
|
|
|
|
diff --git a/cmds/incidentd/src/IncidentService.cpp b/cmds/incidentd/src/IncidentService.cpp
|
|
index a52726396b53..a4819633efee 100644
|
|
--- a/cmds/incidentd/src/IncidentService.cpp
|
|
+++ b/cmds/incidentd/src/IncidentService.cpp
|
|
@@ -418,9 +418,13 @@ status_t IncidentService::onTransact(uint32_t code, const Parcel& data, Parcel*
|
|
|
|
switch (code) {
|
|
case SHELL_COMMAND_TRANSACTION: {
|
|
- int in = data.readFileDescriptor();
|
|
- int out = data.readFileDescriptor();
|
|
- int err = data.readFileDescriptor();
|
|
+ unique_fd in, out, err;
|
|
+ if (status_t status = data.readUniqueFileDescriptor(&in); status != OK) return status;
|
|
+
|
|
+ if (status_t status = data.readUniqueFileDescriptor(&out); status != OK) return status;
|
|
+
|
|
+ if (status_t status = data.readUniqueFileDescriptor(&err); status != OK) return status;
|
|
+
|
|
int argc = data.readInt32();
|
|
Vector<String8> args;
|
|
for (int i = 0; i < argc && data.dataAvail() > 0; i++) {
|
|
@@ -430,15 +434,15 @@ status_t IncidentService::onTransact(uint32_t code, const Parcel& data, Parcel*
|
|
sp<IResultReceiver> resultReceiver =
|
|
IResultReceiver::asInterface(data.readStrongBinder());
|
|
|
|
- FILE* fin = fdopen(in, "r");
|
|
- FILE* fout = fdopen(out, "w");
|
|
- FILE* ferr = fdopen(err, "w");
|
|
+ FILE* fin = fdopen(in.release(), "r");
|
|
+ FILE* fout = fdopen(out.release(), "w");
|
|
+ FILE* ferr = fdopen(err.release(), "w");
|
|
|
|
if (fin == NULL || fout == NULL || ferr == NULL) {
|
|
resultReceiver->send(NO_MEMORY);
|
|
} else {
|
|
- err = command(fin, fout, ferr, args);
|
|
- resultReceiver->send(err);
|
|
+ status_t result = command(fin, fout, ferr, args);
|
|
+ resultReceiver->send(result);
|
|
}
|
|
|
|
if (fin != NULL) {
|