diff options
| -rw-r--r-- | libs/gui/ISurfaceComposer.cpp | 2 | ||||
| -rw-r--r-- | libs/gui/SurfaceComposerClient.cpp | 3 | ||||
| -rw-r--r-- | libs/gui/include/gui/ISurfaceComposer.h | 2 | ||||
| -rw-r--r-- | libs/gui/tests/Surface_test.cpp | 2 | ||||
| -rw-r--r-- | services/surfaceflinger/SurfaceFlinger.cpp | 4 | ||||
| -rw-r--r-- | services/surfaceflinger/SurfaceFlinger.h | 2 | ||||
| -rw-r--r-- | services/surfaceflinger/fuzzer/surfaceflinger_fuzzers_utils.h | 2 | ||||
| -rw-r--r-- | services/surfaceflinger/tests/Credentials_test.cpp | 51 | ||||
| -rw-r--r-- | services/surfaceflinger/tests/unittests/TestableSurfaceFlinger.h | 2 | 
9 files changed, 61 insertions, 9 deletions
| diff --git a/libs/gui/ISurfaceComposer.cpp b/libs/gui/ISurfaceComposer.cpp index b526a6c92c..fc619c32ed 100644 --- a/libs/gui/ISurfaceComposer.cpp +++ b/libs/gui/ISurfaceComposer.cpp @@ -61,7 +61,7 @@ public:      status_t setTransactionState(              const FrameTimelineInfo& frameTimelineInfo, Vector<ComposerState>& state, -            const Vector<DisplayState>& displays, uint32_t flags, const sp<IBinder>& applyToken, +            Vector<DisplayState>& displays, uint32_t flags, const sp<IBinder>& applyToken,              InputWindowCommands commands, int64_t desiredPresentTime, bool isAutoTimestamp,              const std::vector<client_cache_t>& uncacheBuffers, bool hasListenerCallbacks,              const std::vector<ListenerCallbacks>& listenerCallbacks, uint64_t transactionId, diff --git a/libs/gui/SurfaceComposerClient.cpp b/libs/gui/SurfaceComposerClient.cpp index 0fda358b63..4c561cc26f 100644 --- a/libs/gui/SurfaceComposerClient.cpp +++ b/libs/gui/SurfaceComposerClient.cpp @@ -1047,7 +1047,8 @@ void SurfaceComposerClient::doUncacheBufferTransaction(uint64_t cacheId) {      uncacheBuffer.token = BufferCache::getInstance().getToken();      uncacheBuffer.id = cacheId;      Vector<ComposerState> composerStates; -    status_t status = sf->setTransactionState(FrameTimelineInfo{}, composerStates, {}, +    Vector<DisplayState> displayStates; +    status_t status = sf->setTransactionState(FrameTimelineInfo{}, composerStates, displayStates,                                                ISurfaceComposer::eOneWay,                                                Transaction::getDefaultApplyToken(), {}, systemTime(),                                                true, {uncacheBuffer}, false, {}, generateId(), {}); diff --git a/libs/gui/include/gui/ISurfaceComposer.h b/libs/gui/include/gui/ISurfaceComposer.h index 3ff6735926..2790167191 100644 --- a/libs/gui/include/gui/ISurfaceComposer.h +++ b/libs/gui/include/gui/ISurfaceComposer.h @@ -113,7 +113,7 @@ public:      /* open/close transactions. requires ACCESS_SURFACE_FLINGER permission */      virtual status_t setTransactionState(              const FrameTimelineInfo& frameTimelineInfo, Vector<ComposerState>& state, -            const Vector<DisplayState>& displays, uint32_t flags, const sp<IBinder>& applyToken, +            Vector<DisplayState>& displays, uint32_t flags, const sp<IBinder>& applyToken,              InputWindowCommands inputWindowCommands, int64_t desiredPresentTime,              bool isAutoTimestamp, const std::vector<client_cache_t>& uncacheBuffer,              bool hasListenerCallbacks, const std::vector<ListenerCallbacks>& listenerCallbacks, diff --git a/libs/gui/tests/Surface_test.cpp b/libs/gui/tests/Surface_test.cpp index 8d7cf07b96..d351e28ca9 100644 --- a/libs/gui/tests/Surface_test.cpp +++ b/libs/gui/tests/Surface_test.cpp @@ -697,7 +697,7 @@ public:      status_t setTransactionState(              const FrameTimelineInfo& /*frameTimelineInfo*/, Vector<ComposerState>& /*state*/, -            const Vector<DisplayState>& /*displays*/, uint32_t /*flags*/, +            Vector<DisplayState>& /*displays*/, uint32_t /*flags*/,              const sp<IBinder>& /*applyToken*/, InputWindowCommands /*inputWindowCommands*/,              int64_t /*desiredPresentTime*/, bool /*isAutoTimestamp*/,              const std::vector<client_cache_t>& /*cachedBuffer*/, bool /*hasListenerCallbacks*/, diff --git a/services/surfaceflinger/SurfaceFlinger.cpp b/services/surfaceflinger/SurfaceFlinger.cpp index d606788053..e90b66ec8d 100644 --- a/services/surfaceflinger/SurfaceFlinger.cpp +++ b/services/surfaceflinger/SurfaceFlinger.cpp @@ -4502,7 +4502,7 @@ bool SurfaceFlinger::shouldLatchUnsignaled(const sp<Layer>& layer, const layer_s  status_t SurfaceFlinger::setTransactionState(          const FrameTimelineInfo& frameTimelineInfo, Vector<ComposerState>& states, -        const Vector<DisplayState>& displays, uint32_t flags, const sp<IBinder>& applyToken, +        Vector<DisplayState>& displays, uint32_t flags, const sp<IBinder>& applyToken,          InputWindowCommands inputWindowCommands, int64_t desiredPresentTime, bool isAutoTimestamp,          const std::vector<client_cache_t>& uncacheBuffers, bool hasListenerCallbacks,          const std::vector<ListenerCallbacks>& listenerCallbacks, uint64_t transactionId, @@ -4517,7 +4517,7 @@ status_t SurfaceFlinger::setTransactionState(          composerState.state.sanitize(permissions);      } -    for (DisplayState display : displays) { +    for (DisplayState& display : displays) {          display.sanitize(permissions);      } diff --git a/services/surfaceflinger/SurfaceFlinger.h b/services/surfaceflinger/SurfaceFlinger.h index d4700a4e25..aa2f074191 100644 --- a/services/surfaceflinger/SurfaceFlinger.h +++ b/services/surfaceflinger/SurfaceFlinger.h @@ -517,7 +517,7 @@ private:      sp<IBinder> getPhysicalDisplayToken(PhysicalDisplayId displayId) const;      status_t setTransactionState(              const FrameTimelineInfo& frameTimelineInfo, Vector<ComposerState>& state, -            const Vector<DisplayState>& displays, uint32_t flags, const sp<IBinder>& applyToken, +            Vector<DisplayState>& displays, uint32_t flags, const sp<IBinder>& applyToken,              InputWindowCommands inputWindowCommands, int64_t desiredPresentTime,              bool isAutoTimestamp, const std::vector<client_cache_t>& uncacheBuffers,              bool hasListenerCallbacks, const std::vector<ListenerCallbacks>& listenerCallbacks, diff --git a/services/surfaceflinger/fuzzer/surfaceflinger_fuzzers_utils.h b/services/surfaceflinger/fuzzer/surfaceflinger_fuzzers_utils.h index 4d03be04b3..f05b9e6633 100644 --- a/services/surfaceflinger/fuzzer/surfaceflinger_fuzzers_utils.h +++ b/services/surfaceflinger/fuzzer/surfaceflinger_fuzzers_utils.h @@ -739,7 +739,7 @@ public:      auto setTransactionState(              const FrameTimelineInfo& frameTimelineInfo, Vector<ComposerState>& states, -            const Vector<DisplayState>& displays, uint32_t flags, const sp<IBinder>& applyToken, +            Vector<DisplayState>& displays, uint32_t flags, const sp<IBinder>& applyToken,              const InputWindowCommands& inputWindowCommands, int64_t desiredPresentTime,              bool isAutoTimestamp, const std::vector<client_cache_t>& uncacheBuffers,              bool hasListenerCallbacks, std::vector<ListenerCallbacks>& listenerCallbacks, diff --git a/services/surfaceflinger/tests/Credentials_test.cpp b/services/surfaceflinger/tests/Credentials_test.cpp index 2d18166da5..0599858f8e 100644 --- a/services/surfaceflinger/tests/Credentials_test.cpp +++ b/services/surfaceflinger/tests/Credentials_test.cpp @@ -27,6 +27,7 @@  #include <private/android_filesystem_config.h>  #include <private/gui/ComposerServiceAIDL.h>  #include <ui/DisplayMode.h> +#include <ui/DisplayState.h>  #include <ui/DynamicDisplayInfo.h>  #include <utils/String8.h>  #include <functional> @@ -439,6 +440,56 @@ TEST_F(CredentialsTest, TransactionPermissionTest) {      }  } +TEST_F(CredentialsTest, DisplayTransactionPermissionTest) { +    const auto display = getFirstDisplayToken(); + +    ui::DisplayState displayState; +    ASSERT_EQ(NO_ERROR, SurfaceComposerClient::getDisplayState(display, &displayState)); +    const ui::Rotation initialOrientation = displayState.orientation; + +    // Set display orientation from an untrusted process. This should fail silently. +    { +        UIDFaker f{AID_BIN}; +        Transaction transaction; +        Rect layerStackRect; +        Rect displayRect; +        transaction.setDisplayProjection(display, initialOrientation + ui::ROTATION_90, +                                         layerStackRect, displayRect); +        transaction.apply(/*synchronous=*/true); +    } + +    // Verify that the display orientation did not change. +    ASSERT_EQ(NO_ERROR, SurfaceComposerClient::getDisplayState(display, &displayState)); +    ASSERT_EQ(initialOrientation, displayState.orientation); + +    // Set display orientation from a trusted process. +    { +        UIDFaker f{AID_SYSTEM}; +        Transaction transaction; +        Rect layerStackRect; +        Rect displayRect; +        transaction.setDisplayProjection(display, initialOrientation + ui::ROTATION_90, +                                         layerStackRect, displayRect); +        transaction.apply(/*synchronous=*/true); +    } + +    // Verify that the display orientation did change. +    ASSERT_EQ(NO_ERROR, SurfaceComposerClient::getDisplayState(display, &displayState)); +    ASSERT_EQ(initialOrientation + ui::ROTATION_90, displayState.orientation); + +    // Reset orientation +    { +        UIDFaker f{AID_SYSTEM}; +        Transaction transaction; +        Rect layerStackRect; +        Rect displayRect; +        transaction.setDisplayProjection(display, initialOrientation, layerStackRect, displayRect); +        transaction.apply(/*synchronous=*/true); +    } +    ASSERT_EQ(NO_ERROR, SurfaceComposerClient::getDisplayState(display, &displayState)); +    ASSERT_EQ(initialOrientation, displayState.orientation); +} +  } // namespace android  // TODO(b/129481165): remove the #pragma below and fix conversion issues diff --git a/services/surfaceflinger/tests/unittests/TestableSurfaceFlinger.h b/services/surfaceflinger/tests/unittests/TestableSurfaceFlinger.h index 945e48842d..2464f53d95 100644 --- a/services/surfaceflinger/tests/unittests/TestableSurfaceFlinger.h +++ b/services/surfaceflinger/tests/unittests/TestableSurfaceFlinger.h @@ -468,7 +468,7 @@ public:      auto setTransactionState(              const FrameTimelineInfo& frameTimelineInfo, Vector<ComposerState>& states, -            const Vector<DisplayState>& displays, uint32_t flags, const sp<IBinder>& applyToken, +            Vector<DisplayState>& displays, uint32_t flags, const sp<IBinder>& applyToken,              const InputWindowCommands& inputWindowCommands, int64_t desiredPresentTime,              bool isAutoTimestamp, const std::vector<client_cache_t>& uncacheBuffers,              bool hasListenerCallbacks, std::vector<ListenerCallbacks>& listenerCallbacks, |