From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753767AbcKMPJe (ORCPT ); Sun, 13 Nov 2016 10:09:34 -0500 Received: from mail-it0-f67.google.com ([209.85.214.67]:33596 "EHLO mail-it0-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752903AbcKMPJd (ORCPT ); Sun, 13 Nov 2016 10:09:33 -0500 MIME-Version: 1.0 X-Originating-IP: [2a02:168:56b5:0:ac27:b86c:7764:9429] In-Reply-To: <1478971198-3659-1-git-send-email-Julia.Lawall@lip6.fr> References: <1478971198-3659-1-git-send-email-Julia.Lawall@lip6.fr> From: Daniel Vetter Date: Sun, 13 Nov 2016 16:09:31 +0100 X-Google-Sender-Auth: BK1sYIMqRiUFIXeqKjkxvLbqyYM Message-ID: Subject: Re: [PATCH] drm/sun4i: constify component_ops structures To: Julia Lawall Cc: Maxime Ripard , kernel-janitors@vger.kernel.org, Linux Kernel Mailing List , dri-devel , Chen-Yu Tsai , Bhumika Goyal , "linux-arm-kernel@lists.infradead.org" Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sat, Nov 12, 2016 at 6:19 PM, Julia Lawall wrote: > These component_ops structures are only used as the second argument to > component_add and component_del, which are declared as const, so the > structures can be declared as const as well. > > The semantic patch that makes this change is as follows: > (http://coccinelle.lip6.fr/) > > // > @r disable optional_qualifier@ > identifier i; > position p; > @@ > > static struct component_ops i@p = { ... }; > > @ok1@ > identifier r.i; > expression e1; > position p; > @@ > > component_add(e1,&i@p) > > @ok2@ > identifier r.i; > expression e1; > position p; > @@ > > component_del(e1, &i@p) > > @bad@ > position p != {r.p,ok1.p,ok2.p}; > identifier r.i; > struct component_ops e; > @@ > > e@i@p > > @depends on !bad disable optional_qualifier@ > identifier r.i; > @@ > > static > +const > struct component_ops i = { ... }; > // > > The result of the size command before the change is (arm): > > text data bss dec hex filename > 5266 236 8 5510 1586 sun4i_backend.o > 6393 236 8 6637 19ed sun4i_tcon.o > 3700 368 8 4076 fec sun4i_tv.o > 1668 108 0 1776 6f0 sun6i_drc.o > > and after the change: > > text data bss dec hex filename > 5274 228 8 5510 1586 sun4i_backend.o > 6401 228 8 6637 19ed sun4i_tcon.o > 3708 360 8 4076 fec sun4i_tv.o > 1676 100 0 1776 6f0 sun6i_drc.o > > Signed-off-by: Julia Lawall Applied to drm-misc, thanks. -Daniel > > --- > drivers/gpu/drm/sun4i/sun4i_backend.c | 2 +- > drivers/gpu/drm/sun4i/sun4i_tcon.c | 2 +- > drivers/gpu/drm/sun4i/sun4i_tv.c | 2 +- > drivers/gpu/drm/sun4i/sun6i_drc.c | 2 +- > 4 files changed, 4 insertions(+), 4 deletions(-) > > diff --git a/drivers/gpu/drm/sun4i/sun4i_backend.c b/drivers/gpu/drm/sun4i/sun4i_backend.c > index 7eb2a96..2e08f96 100644 > --- a/drivers/gpu/drm/sun4i/sun4i_backend.c > +++ b/drivers/gpu/drm/sun4i/sun4i_backend.c > @@ -409,7 +409,7 @@ static void sun4i_backend_unbind(struct device *dev, struct device *master, > reset_control_assert(backend->reset); > } > > -static struct component_ops sun4i_backend_ops = { > +static const struct component_ops sun4i_backend_ops = { > .bind = sun4i_backend_bind, > .unbind = sun4i_backend_unbind, > }; > diff --git a/drivers/gpu/drm/sun4i/sun4i_tcon.c b/drivers/gpu/drm/sun4i/sun4i_tcon.c > index c6afb24..ea2906f 100644 > --- a/drivers/gpu/drm/sun4i/sun4i_tcon.c > +++ b/drivers/gpu/drm/sun4i/sun4i_tcon.c > @@ -545,7 +545,7 @@ static void sun4i_tcon_unbind(struct device *dev, struct device *master, > sun4i_tcon_free_clocks(tcon); > } > > -static struct component_ops sun4i_tcon_ops = { > +static const struct component_ops sun4i_tcon_ops = { > .bind = sun4i_tcon_bind, > .unbind = sun4i_tcon_unbind, > }; > diff --git a/drivers/gpu/drm/sun4i/sun4i_tv.c b/drivers/gpu/drm/sun4i/sun4i_tv.c > index 1dd3d9e..d430b331 100644 > --- a/drivers/gpu/drm/sun4i/sun4i_tv.c > +++ b/drivers/gpu/drm/sun4i/sun4i_tv.c > @@ -667,7 +667,7 @@ static void sun4i_tv_unbind(struct device *dev, struct device *master, > clk_disable_unprepare(tv->clk); > } > > -static struct component_ops sun4i_tv_ops = { > +static const struct component_ops sun4i_tv_ops = { > .bind = sun4i_tv_bind, > .unbind = sun4i_tv_unbind, > }; > diff --git a/drivers/gpu/drm/sun4i/sun6i_drc.c b/drivers/gpu/drm/sun4i/sun6i_drc.c > index 6ef707c..09bba85 100644 > --- a/drivers/gpu/drm/sun4i/sun6i_drc.c > +++ b/drivers/gpu/drm/sun4i/sun6i_drc.c > @@ -80,7 +80,7 @@ static void sun6i_drc_unbind(struct device *dev, struct device *master, > reset_control_assert(drc->reset); > } > > -static struct component_ops sun6i_drc_ops = { > +static const struct component_ops sun6i_drc_ops = { > .bind = sun6i_drc_bind, > .unbind = sun6i_drc_unbind, > }; > > _______________________________________________ > dri-devel mailing list > dri-devel@lists.freedesktop.org > https://lists.freedesktop.org/mailman/listinfo/dri-devel -- Daniel Vetter Software Engineer, Intel Corporation +41 (0) 79 365 57 48 - http://blog.ffwll.ch