Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754807AbdIHGES (ORCPT ); Fri, 8 Sep 2017 02:04:18 -0400 Received: from mailout1.samsung.com ([203.254.224.24]:48822 "EHLO mailout1.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754443AbdIHGDM (ORCPT ); Fri, 8 Sep 2017 02:03:12 -0400 X-AuditID: b6c32a36-f79196d0000051db-9b-59b2329d8390 From: Hoegeun Kwon To: inki.dae@samsung.com, airlied@linux.ie, kgene@kernel.org, krzk@kernel.org, robh+dt@kernel.org, mark.rutland@arm.com, catalin.marinas@arm.com, will.deacon@arm.com, mchehab@kernel.org, s.nawrocki@samsung.com, m.szyprowski@samsung.com Cc: dri-devel@lists.freedesktop.org, linux-media@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-samsung-soc@vger.kernel.org, linux-kernel@vger.kernel.org, devicetree@vger.kernel.org, a.hajda@samsung.com, Hoegeun Kwon Subject: [PATCH v3 4/6] [media] exynos-gsc: Add hardware rotation limits Date: Fri, 08 Sep 2017 15:02:38 +0900 Message-id: <1504850560-27950-5-git-send-email-hoegeun.kwon@samsung.com> X-Mailer: git-send-email 1.9.1 In-reply-to: <1504850560-27950-1-git-send-email-hoegeun.kwon@samsung.com> X-Brightmail-Tracker: H4sIAAAAAAAAAzWSWUwTYRDH/bbd3WKo2RTRLxAJbtRETWt3LfVDxXhnjT7UoIloDG5gQ4k9 yG4x6ovwUNCKAmqMyuEFaCog1gMiqBGKWKMtKh4xICKJBlQQEYy32y6+/Wfm95/MTEaj0n3H 4zTZDpcgOngbTUxW32iba9RXsL40o/vXLPSqPoijQ8EAhoZrigA67ZfDrrFhAg1f8BDoSG+J GhX3f1ChUKiBRL7+5zh6erOcQEUN13F0InQbQ3X+HhJVv3iMoRrfLwy5b/lJ1PaxEEcDI/fV y2O42spawPm8BwiucfwNzvUe7MC4q1X7uMPXvIAb9SVYyK3CUqvAZwpiouDIcGZmO7JS6PWp 6avSk8xGRs8ko0V0ooO3Cyn06g0W/dpsm7wLnbiLt+XKKQsvSfSCZUtFZ65LSLQ6JVcKvY1h WANjXGRgWdZgWrh9MZskIzsE66PPn8icwZm7G9+OqvNAY7wHRGkgZYID7gG1oqfBzteXCQ+Y rNFRTQAODX/HwwUd9Q3AH4VmD9BEDF0v5yhMA4DVjQWYEsjM2dOvVGEDQenhWNGLSGEqNQLg 26FAJFBRhRjsCzaQYSqG4uB1zzsQ1mpqNgyVFUe0Vs4fv7GfUGZKgIF7RyNjRFHroLv3CQg3 gtQoAfs+v8MVaDWsrHhPKjoGDnZcI5VZ4+GT9hQlvQ8+bQpMePMALC4tm+AXwgeefCysVdQU ODRWhCteLdxfoFMQDnbmBydaroD5FeuVjcsBDHR/AyUg/gyY5AXThBzJniVITA5rkHi7lOvI MmQ47T4Qebt55iZwLrihFVAaQEdrSzZfSdPh/C5pj70VQI2Knqr9q/el6bSZ/J69guhMF3Nt gtQKkuTTlKriYjOc8hM7XOmMKdloMrPyXyQzDD1dG3v5+RYdlcW7hJ2CkCOI/32YJiouD8R5 bWbL7raeZ7HdnYXNp75c7Fxyl51rGYz+U03g23w7bHeOieKH9k9k36XzrP119+/y+AM/guVJ P0fyyhz+qunNJ8fnr2zpsUYXrLln8jPuio470tCmEbJlxs/a+uPEpVWhFYaNVaWTznyFqQkl dd5bmZX9D8X2rgVHz8Fxa/Q6Wi1ZeWaeSpT4f1dLo7OMAwAA X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFrrELMWRmVeSWpSXmKPExsVy+t9jQd25RpsiDa418VjcWneO1aL33Ekm i/fLehgt5h8Bcq98fc9m8X55F5vFpPsTWCz6H79mtjh/fgO7xabH11gtLu+aw2bRs2Erq8WM 8/uYLNYeuctusfT6RSaLZZv+MFm07j3CbnH4TTurxcuPJ1gchD3WzFvD6LFpVSebx/ZvD1g9 7ncfZ/LYvKTeo2/LKkaPz5vkAtijuGxSUnMyy1KL9O0SuDLOfnjLXvBKsWL7o88sDYzbpbsY OTgkBEwkrtxQ62Lk4hASWMcosfD4blYI5zujxOqjNxi7GDk52AR0Jb72XGcCSYgIfGSUeLa+ kR3EYRZoZ5KYefslO0iVsICHxNauZ2AdLAKqEudn94PZvEDxads62EBsCQE5iZPHJrOC2JwC nhKt9y+B1QgB1ew5vZh9AiPPAkaGVYySqQXFuem5xUYFhnmp5XrFibnFpXnpesn5uZsYgSG9 7bBW3w7G+0viDzEKcDAq8fBaBG+MFGJNLCuuzD3EKMHBrCTC+193U6QQb0piZVVqUX58UWlO avEhRmkOFiVx3sy+GZFCAumJJanZqakFqUUwWSYOTqkGxkiz9ktiNbbzf5Y9kf59wnAGp7Ut k0eZkbCFu9RO/oeut2OXS1hanQvMr0q5YMTZrWrR+nwic9vkn+cZWf2N/hTslz01PYWp0rsg yH6nP499Xc6fS0vrmfz/x1lv/HrcRu7JiQMcC12iMs2+H+Z7l52m3TaxJ3VjvZaYSQ3v5DOO Rw/tzRRSYinOSDTUYi4qTgQARZP3IGUCAAA= X-CMS-MailID: 20170908060309epcas1p3d48dd0871d3fde02ba3c9921bbe5a7a6 X-Msg-Generator: CA X-Sender-IP: 182.195.42.142 X-Local-Sender: =?UTF-8?B?6raM7ZqM6re8G1RpemVuIFBsYXRmb3JtIExhYihTL1fshLw=?= =?UTF-8?B?7YSwKRvsgrzshLHsoITsnpAbRW5naW5lZXI=?= X-Global-Sender: =?UTF-8?B?SG9lZ2V1biBLd29uG1RpemVuIFBsYXRmb3JtIExhYi4bU2Ft?= =?UTF-8?B?c3VuZyBFbGVjdHJvbmljcxtFbmdpbmVlcg==?= X-Sender-Code: =?UTF-8?B?QzEwG1RFTEUbQzEwVjgxMTE=?= CMS-TYPE: 101P DLP-Filter: Pass X-CFilter-Loop: Reflected X-CMS-RootMailID: 20170908060309epcas1p3d48dd0871d3fde02ba3c9921bbe5a7a6 X-RootMTR: 20170908060309epcas1p3d48dd0871d3fde02ba3c9921bbe5a7a6 References: <1504850560-27950-1-git-send-email-hoegeun.kwon@samsung.com> Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 4182 Lines: 146 The hardware rotation limits of gsc depends on SOC (Exynos 5250/5420/5433). Distinguish them and add them to the driver data. Signed-off-by: Hoegeun Kwon --- drivers/media/platform/exynos-gsc/gsc-core.c | 96 ++++++++++++++++++++++++---- 1 file changed, 83 insertions(+), 13 deletions(-) diff --git a/drivers/media/platform/exynos-gsc/gsc-core.c b/drivers/media/platform/exynos-gsc/gsc-core.c index 4380150..8f8636e 100644 --- a/drivers/media/platform/exynos-gsc/gsc-core.c +++ b/drivers/media/platform/exynos-gsc/gsc-core.c @@ -943,7 +943,37 @@ static irqreturn_t gsc_irq_handler(int irq, void *priv) return IRQ_HANDLED; } -static struct gsc_pix_max gsc_v_100_max = { +static struct gsc_pix_max gsc_v_5250_max = { + .org_scaler_bypass_w = 8192, + .org_scaler_bypass_h = 8192, + .org_scaler_input_w = 4800, + .org_scaler_input_h = 3344, + .real_rot_dis_w = 4800, + .real_rot_dis_h = 3344, + .real_rot_en_w = 2016, + .real_rot_en_h = 2016, + .target_rot_dis_w = 4800, + .target_rot_dis_h = 3344, + .target_rot_en_w = 2016, + .target_rot_en_h = 2016, +}; + +static struct gsc_pix_max gsc_v_5420_max = { + .org_scaler_bypass_w = 8192, + .org_scaler_bypass_h = 8192, + .org_scaler_input_w = 4800, + .org_scaler_input_h = 3344, + .real_rot_dis_w = 4800, + .real_rot_dis_h = 3344, + .real_rot_en_w = 2048, + .real_rot_en_h = 2048, + .target_rot_dis_w = 4800, + .target_rot_dis_h = 3344, + .target_rot_en_w = 2016, + .target_rot_en_h = 2016, +}; + +static struct gsc_pix_max gsc_v_5433_max = { .org_scaler_bypass_w = 8192, .org_scaler_bypass_h = 8192, .org_scaler_input_w = 4800, @@ -979,8 +1009,8 @@ static irqreturn_t gsc_irq_handler(int irq, void *priv) .target_h = 2, /* yuv420 : 2, others : 1 */ }; -static struct gsc_variant gsc_v_100_variant = { - .pix_max = &gsc_v_100_max, +static struct gsc_variant gsc_v_5250_variant = { + .pix_max = &gsc_v_5250_max, .pix_min = &gsc_v_100_min, .pix_align = &gsc_v_100_align, .in_buf_cnt = 32, @@ -992,12 +1022,48 @@ static irqreturn_t gsc_irq_handler(int irq, void *priv) .local_sc_down = 2, }; -static struct gsc_driverdata gsc_v_100_drvdata = { +static struct gsc_variant gsc_v_5420_variant = { + .pix_max = &gsc_v_5420_max, + .pix_min = &gsc_v_100_min, + .pix_align = &gsc_v_100_align, + .in_buf_cnt = 32, + .out_buf_cnt = 32, + .sc_up_max = 8, + .sc_down_max = 16, + .poly_sc_down_max = 4, + .pre_sc_down_max = 4, + .local_sc_down = 2, +}; + +static struct gsc_variant gsc_v_5433_variant = { + .pix_max = &gsc_v_5433_max, + .pix_min = &gsc_v_100_min, + .pix_align = &gsc_v_100_align, + .in_buf_cnt = 32, + .out_buf_cnt = 32, + .sc_up_max = 8, + .sc_down_max = 16, + .poly_sc_down_max = 4, + .pre_sc_down_max = 4, + .local_sc_down = 2, +}; + +static struct gsc_driverdata gsc_v_5250_drvdata = { .variant = { - [0] = &gsc_v_100_variant, - [1] = &gsc_v_100_variant, - [2] = &gsc_v_100_variant, - [3] = &gsc_v_100_variant, + [0] = &gsc_v_5250_variant, + [1] = &gsc_v_5250_variant, + [2] = &gsc_v_5250_variant, + [3] = &gsc_v_5250_variant, + }, + .num_entities = 4, + .clk_names = { "gscl" }, + .num_clocks = 1, +}; + +static struct gsc_driverdata gsc_v_5420_drvdata = { + .variant = { + [0] = &gsc_v_5420_variant, + [1] = &gsc_v_5420_variant, }, .num_entities = 4, .clk_names = { "gscl" }, @@ -1006,9 +1072,9 @@ static irqreturn_t gsc_irq_handler(int irq, void *priv) static struct gsc_driverdata gsc_5433_drvdata = { .variant = { - [0] = &gsc_v_100_variant, - [1] = &gsc_v_100_variant, - [2] = &gsc_v_100_variant, + [0] = &gsc_v_5433_variant, + [1] = &gsc_v_5433_variant, + [2] = &gsc_v_5433_variant, }, .num_entities = 3, .clk_names = { "pclk", "aclk", "aclk_xiu", "aclk_gsclbend" }, @@ -1017,8 +1083,12 @@ static irqreturn_t gsc_irq_handler(int irq, void *priv) static const struct of_device_id exynos_gsc_match[] = { { - .compatible = "samsung,exynos5-gsc", - .data = &gsc_v_100_drvdata, + .compatible = "samsung,exynos5250-gsc", + .data = &gsc_v_5250_drvdata, + }, + { + .compatible = "samsung,exynos5420-gsc", + .data = &gsc_v_5420_drvdata, }, { .compatible = "samsung,exynos5433-gsc", -- 1.9.1