Commit 960b537e authored by Arnd Bergmann's avatar Arnd Bergmann Committed by Inki Dae

drm/exynos: fix accidental on-stack copy of exynos_drm_plane

gcc rightfully complains about excessive stack usage in the fimd_win_set_pixfmt()
function:

drivers/gpu/drm/exynos/exynos_drm_fimd.c: In function 'fimd_win_set_pixfmt':
drivers/gpu/drm/exynos/exynos_drm_fimd.c:750:1: error: the frame size of 1032 bytes is larger than 1024 byte
drivers/gpu/drm/exynos/exynos5433_drm_decon.c: In function 'decon_win_set_pixfmt':
drivers/gpu/drm/exynos/exynos5433_drm_decon.c:381:1: error: the frame size of 1032 bytes is larger than 1024 bytes

There is really no reason to copy the large exynos_drm_plane
structure to the stack before using one of its members, so just
use a pointer instead.

Fixes: 6f8ee5c2 ("drm/exynos: fimd: Make plane alpha configurable")
Signed-off-by: default avatarArnd Bergmann <arnd@arndb.de>
Reviewed-by: default avatarMarek Szyprowski <m.szyprowski@samsung.com>
Signed-off-by: default avatarInki Dae <inki.dae@samsung.com>
parent 477552e1
...@@ -319,9 +319,9 @@ static void decon_win_set_bldmod(struct decon_context *ctx, unsigned int win, ...@@ -319,9 +319,9 @@ static void decon_win_set_bldmod(struct decon_context *ctx, unsigned int win,
static void decon_win_set_pixfmt(struct decon_context *ctx, unsigned int win, static void decon_win_set_pixfmt(struct decon_context *ctx, unsigned int win,
struct drm_framebuffer *fb) struct drm_framebuffer *fb)
{ {
struct exynos_drm_plane plane = ctx->planes[win]; struct exynos_drm_plane *plane = &ctx->planes[win];
struct exynos_drm_plane_state *state = struct exynos_drm_plane_state *state =
to_exynos_plane_state(plane.base.state); to_exynos_plane_state(plane->base.state);
unsigned int alpha = state->base.alpha; unsigned int alpha = state->base.alpha;
unsigned int pixel_alpha; unsigned int pixel_alpha;
unsigned long val; unsigned long val;
......
...@@ -661,9 +661,9 @@ static void fimd_win_set_bldmod(struct fimd_context *ctx, unsigned int win, ...@@ -661,9 +661,9 @@ static void fimd_win_set_bldmod(struct fimd_context *ctx, unsigned int win,
static void fimd_win_set_pixfmt(struct fimd_context *ctx, unsigned int win, static void fimd_win_set_pixfmt(struct fimd_context *ctx, unsigned int win,
struct drm_framebuffer *fb, int width) struct drm_framebuffer *fb, int width)
{ {
struct exynos_drm_plane plane = ctx->planes[win]; struct exynos_drm_plane *plane = &ctx->planes[win];
struct exynos_drm_plane_state *state = struct exynos_drm_plane_state *state =
to_exynos_plane_state(plane.base.state); to_exynos_plane_state(plane->base.state);
uint32_t pixel_format = fb->format->format; uint32_t pixel_format = fb->format->format;
unsigned int alpha = state->base.alpha; unsigned int alpha = state->base.alpha;
u32 val = WINCONx_ENWIN; u32 val = WINCONx_ENWIN;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment