[PATCH 1/2] drm/i915/gvt: give the cmd parser decode_info a const treatment

Zhao, Yan Y yan.y.zhao at intel.com
Thu Jan 10 02:51:25 UTC 2019


Looks good to me.
Reviewed-by: Yan Zhao <yan.y.zhao at intel.com>

> -----Original Message-----
> From: intel-gvt-dev [mailto:intel-gvt-dev-bounces at lists.freedesktop.org] On
> Behalf Of Jani Nikula
> Sent: Tuesday, January 8, 2019 10:12 PM
> To: intel-gvt-dev at lists.freedesktop.org
> Cc: Nikula, Jani <jani.nikula at intel.com>; intel-gfx at lists.freedesktop.org; Wang,
> Zhi A <zhi.a.wang at intel.com>; zhenyuw at linux.intel.com
> Subject: [PATCH 1/2] drm/i915/gvt: give the cmd parser decode_info a const
> treatment
> 
> It doesn't need to be changed, make it const. The string literals should anyway
> be referred to as const data.
> 
> The following gets moved to rodata section:
> 
> 0000000000000410 l     O .rodata	0000000000000018 decode_info_mi
> 0000000000000390 l     O .rodata	0000000000000018
> decode_info_3d_media
> 00000000000003e0 l     O .rodata	0000000000000018 decode_info_2d
> 0000000000000330 l     O .rodata	0000000000000018
> decode_info_mfx_vc
> 00000000000002e0 l     O .rodata	0000000000000018
> decode_info_vebox
> 0000000000000300 l     O .rodata	0000000000000028 sub_op_vebox
> 0000000000000360 l     O .rodata	0000000000000028 sub_op_mfx_vc
> 00000000000003c0 l     O .rodata	0000000000000020 sub_op_3d_media
> 0000000000000400 l     O .rodata	0000000000000010 sub_op_2d
> 0000000000000430 l     O .rodata	0000000000000010 sub_op_mi
> 
> Signed-off-by: Jani Nikula <jani.nikula at intel.com>
> ---
>  drivers/gpu/drm/i915/gvt/cmd_parser.c | 30 +++++++++++++--------------
>  1 file changed, 15 insertions(+), 15 deletions(-)
> 
> diff --git a/drivers/gpu/drm/i915/gvt/cmd_parser.c
> b/drivers/gpu/drm/i915/gvt/cmd_parser.c
> index 77ae634eb11c..98415d465a09 100644
> --- a/drivers/gpu/drm/i915/gvt/cmd_parser.c
> +++ b/drivers/gpu/drm/i915/gvt/cmd_parser.c
> @@ -55,10 +55,10 @@ struct sub_op_bits {
>  	int low;
>  };
>  struct decode_info {
> -	char *name;
> +	const char *name;
>  	int op_len;
>  	int nr_sub_op;
> -	struct sub_op_bits *sub_op;
> +	const struct sub_op_bits *sub_op;
>  };
> 
>  #define   MAX_CMD_BUDGET			0x7fffffff
> @@ -485,12 +485,12 @@ struct parser_exec_state {  static unsigned long
> bypass_scan_mask = 0;
> 
>  /* ring ALL, type = 0 */
> -static struct sub_op_bits sub_op_mi[] = {
> +static const struct sub_op_bits sub_op_mi[] = {
>  	{31, 29},
>  	{28, 23},
>  };
> 
> -static struct decode_info decode_info_mi = {
> +static const struct decode_info decode_info_mi = {
>  	"MI",
>  	OP_LEN_MI,
>  	ARRAY_SIZE(sub_op_mi),
> @@ -498,12 +498,12 @@ static struct decode_info decode_info_mi = {  };
> 
>  /* ring RCS, command type 2 */
> -static struct sub_op_bits sub_op_2d[] = {
> +static const struct sub_op_bits sub_op_2d[] = {
>  	{31, 29},
>  	{28, 22},
>  };
> 
> -static struct decode_info decode_info_2d = {
> +static const struct decode_info decode_info_2d = {
>  	"2D",
>  	OP_LEN_2D,
>  	ARRAY_SIZE(sub_op_2d),
> @@ -511,14 +511,14 @@ static struct decode_info decode_info_2d = {  };
> 
>  /* ring RCS, command type 3 */
> -static struct sub_op_bits sub_op_3d_media[] = {
> +static const struct sub_op_bits sub_op_3d_media[] = {
>  	{31, 29},
>  	{28, 27},
>  	{26, 24},
>  	{23, 16},
>  };
> 
> -static struct decode_info decode_info_3d_media = {
> +static const struct decode_info decode_info_3d_media = {
>  	"3D_Media",
>  	OP_LEN_3D_MEDIA,
>  	ARRAY_SIZE(sub_op_3d_media),
> @@ -526,7 +526,7 @@ static struct decode_info decode_info_3d_media = {  };
> 
>  /* ring VCS, command type 3 */
> -static struct sub_op_bits sub_op_mfx_vc[] = {
> +static const struct sub_op_bits sub_op_mfx_vc[] = {
>  	{31, 29},
>  	{28, 27},
>  	{26, 24},
> @@ -534,7 +534,7 @@ static struct sub_op_bits sub_op_mfx_vc[] = {
>  	{20, 16},
>  };
> 
> -static struct decode_info decode_info_mfx_vc = {
> +static const struct decode_info decode_info_mfx_vc = {
>  	"MFX_VC",
>  	OP_LEN_MFX_VC,
>  	ARRAY_SIZE(sub_op_mfx_vc),
> @@ -542,7 +542,7 @@ static struct decode_info decode_info_mfx_vc = {  };
> 
>  /* ring VECS, command type 3 */
> -static struct sub_op_bits sub_op_vebox[] = {
> +static const struct sub_op_bits sub_op_vebox[] = {
>  	{31, 29},
>  	{28, 27},
>  	{26, 24},
> @@ -550,14 +550,14 @@ static struct sub_op_bits sub_op_vebox[] = {
>  	{20, 16},
>  };
> 
> -static struct decode_info decode_info_vebox = {
> +static const struct decode_info decode_info_vebox = {
>  	"VEBOX",
>  	OP_LEN_VEBOX,
>  	ARRAY_SIZE(sub_op_vebox),
>  	sub_op_vebox,
>  };
> 
> -static struct decode_info *ring_decode_info[I915_NUM_ENGINES][8] = {
> +static const struct decode_info *ring_decode_info[I915_NUM_ENGINES][8]
> += {
>  	[RCS] = {
>  		&decode_info_mi,
>  		NULL,
> @@ -616,7 +616,7 @@ static struct decode_info
> *ring_decode_info[I915_NUM_ENGINES][8] = {
> 
>  static inline u32 get_opcode(u32 cmd, int ring_id)  {
> -	struct decode_info *d_info;
> +	const struct decode_info *d_info;
> 
>  	d_info = ring_decode_info[ring_id][CMD_TYPE(cmd)];
>  	if (d_info == NULL)
> @@ -657,7 +657,7 @@ static inline u32 sub_op_val(u32 cmd, u32 hi, u32 low)
> 
>  static inline void print_opcode(u32 cmd, int ring_id)  {
> -	struct decode_info *d_info;
> +	const struct decode_info *d_info;
>  	int i;
> 
>  	d_info = ring_decode_info[ring_id][CMD_TYPE(cmd)];
> --
> 2.20.1
> 
> _______________________________________________
> intel-gvt-dev mailing list
> intel-gvt-dev at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/intel-gvt-dev


More information about the intel-gvt-dev mailing list