Commit 24bb30c8 authored by Sakari Ailus's avatar Sakari Ailus Committed by Mauro Carvalho Chehab

media: v4l: Avoid unaligned access warnings when printing 4cc modifiers

Pointers V4L2 pixelformat and dataformat fields in a few packed structs
are directly passed to printk family of functions. This could result in an
unaligned access albeit no such possibility appears to exist at the
moment i.e. this clang warning appears to be a false positive.

Address the warning by copying the pixelformat or dataformat value to a
local variable first.
Reported-by: default avatarkernel test robot <lkp@intel.com>
Fixes: e927e1e0 ("v4l: ioctl: Use %p4cc printk modifier to print FourCC codes")
Signed-off-by: default avatarSakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@kernel.org>
parent c748f10c
...@@ -279,8 +279,8 @@ static void v4l_print_format(const void *arg, bool write_only) ...@@ -279,8 +279,8 @@ static void v4l_print_format(const void *arg, bool write_only)
const struct v4l2_vbi_format *vbi; const struct v4l2_vbi_format *vbi;
const struct v4l2_sliced_vbi_format *sliced; const struct v4l2_sliced_vbi_format *sliced;
const struct v4l2_window *win; const struct v4l2_window *win;
const struct v4l2_sdr_format *sdr;
const struct v4l2_meta_format *meta; const struct v4l2_meta_format *meta;
u32 pixelformat;
u32 planes; u32 planes;
unsigned i; unsigned i;
...@@ -299,8 +299,9 @@ static void v4l_print_format(const void *arg, bool write_only) ...@@ -299,8 +299,9 @@ static void v4l_print_format(const void *arg, bool write_only)
case V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE: case V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE:
case V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE: case V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE:
mp = &p->fmt.pix_mp; mp = &p->fmt.pix_mp;
pixelformat = mp->pixelformat;
pr_cont(", width=%u, height=%u, format=%p4cc, field=%s, colorspace=%d, num_planes=%u, flags=0x%x, ycbcr_enc=%u, quantization=%u, xfer_func=%u\n", pr_cont(", width=%u, height=%u, format=%p4cc, field=%s, colorspace=%d, num_planes=%u, flags=0x%x, ycbcr_enc=%u, quantization=%u, xfer_func=%u\n",
mp->width, mp->height, &mp->pixelformat, mp->width, mp->height, &pixelformat,
prt_names(mp->field, v4l2_field_names), prt_names(mp->field, v4l2_field_names),
mp->colorspace, mp->num_planes, mp->flags, mp->colorspace, mp->num_planes, mp->flags,
mp->ycbcr_enc, mp->quantization, mp->xfer_func); mp->ycbcr_enc, mp->quantization, mp->xfer_func);
...@@ -343,14 +344,15 @@ static void v4l_print_format(const void *arg, bool write_only) ...@@ -343,14 +344,15 @@ static void v4l_print_format(const void *arg, bool write_only)
break; break;
case V4L2_BUF_TYPE_SDR_CAPTURE: case V4L2_BUF_TYPE_SDR_CAPTURE:
case V4L2_BUF_TYPE_SDR_OUTPUT: case V4L2_BUF_TYPE_SDR_OUTPUT:
sdr = &p->fmt.sdr; pixelformat = p->fmt.sdr.pixelformat;
pr_cont(", pixelformat=%p4cc\n", &sdr->pixelformat); pr_cont(", pixelformat=%p4cc\n", &pixelformat);
break; break;
case V4L2_BUF_TYPE_META_CAPTURE: case V4L2_BUF_TYPE_META_CAPTURE:
case V4L2_BUF_TYPE_META_OUTPUT: case V4L2_BUF_TYPE_META_OUTPUT:
meta = &p->fmt.meta; meta = &p->fmt.meta;
pixelformat = meta->dataformat;
pr_cont(", dataformat=%p4cc, buffersize=%u\n", pr_cont(", dataformat=%p4cc, buffersize=%u\n",
&meta->dataformat, meta->buffersize); &pixelformat, meta->buffersize);
break; break;
} }
} }
......
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