media: replace strcpy() by strscpy()
authorMauro Carvalho Chehab <mchehab+samsung@kernel.org>
Mon, 10 Sep 2018 20:20:42 +0000 (16:20 -0400)
committerMauro Carvalho Chehab <mchehab+samsung@kernel.org>
Tue, 11 Sep 2018 17:32:17 +0000 (13:32 -0400)
The strcpy() function is being deprecated upstream. Replace
it by the safer strscpy().

Signed-off-by: Mauro Carvalho Chehab <mchehab+samsung@kernel.org>
Reviewed-by: Hans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab+samsung@kernel.org>
83 files changed:
drivers/media/common/saa7146/saa7146_video.c
drivers/media/dvb-core/dvb_frontend.c
drivers/media/dvb-frontends/mt312.c
drivers/media/dvb-frontends/zl10039.c
drivers/media/firewire/firedtv-fe.c
drivers/media/i2c/ad5820.c
drivers/media/i2c/lm3560.c
drivers/media/i2c/lm3646.c
drivers/media/i2c/s5c73m3/s5c73m3-core.c
drivers/media/i2c/sr030pc30.c
drivers/media/pci/bt8xx/bttv-driver.c
drivers/media/pci/cx23885/cx23885-417.c
drivers/media/pci/cx23885/cx23885-alsa.c
drivers/media/pci/cx23885/cx23885-video.c
drivers/media/pci/cx25821/cx25821-alsa.c
drivers/media/pci/cx25821/cx25821-video.c
drivers/media/pci/cx88/cx88-alsa.c
drivers/media/pci/cx88/cx88-blackbird.c
drivers/media/pci/cx88/cx88-cards.c
drivers/media/pci/cx88/cx88-video.c
drivers/media/pci/dm1105/dm1105.c
drivers/media/pci/dt3155/dt3155.c
drivers/media/pci/meye/meye.c
drivers/media/pci/ngene/ngene-i2c.c
drivers/media/pci/pluto2/pluto2.c
drivers/media/pci/pt1/pt1.c
drivers/media/pci/saa7134/saa7134-alsa.c
drivers/media/pci/saa7134/saa7134-i2c.c
drivers/media/pci/saa7134/saa7134-video.c
drivers/media/pci/saa7164/saa7164-core.c
drivers/media/pci/saa7164/saa7164-encoder.c
drivers/media/pci/saa7164/saa7164-vbi.c
drivers/media/pci/smipcie/smipcie-main.c
drivers/media/pci/solo6x10/solo6x10-g723.c
drivers/media/pci/solo6x10/solo6x10-v4l2-enc.c
drivers/media/pci/solo6x10/solo6x10-v4l2.c
drivers/media/pci/sta2x11/sta2x11_vip.c
drivers/media/pci/ttpci/av7110_v4l.c
drivers/media/pci/ttpci/budget-core.c
drivers/media/pci/tw5864/tw5864-video.c
drivers/media/pci/tw68/tw68-video.c
drivers/media/platform/am437x/am437x-vpfe.c
drivers/media/platform/atmel/atmel-isc.c
drivers/media/platform/davinci/vpbe_display.c
drivers/media/platform/davinci/vpbe_venc.c
drivers/media/platform/davinci/vpif_capture.c
drivers/media/platform/davinci/vpif_display.c
drivers/media/platform/fsl-viu.c
drivers/media/platform/marvell-ccic/cafe-driver.c
drivers/media/platform/marvell-ccic/mcam-core.c
drivers/media/platform/soc_camera/soc_camera.c
drivers/media/platform/via-camera.c
drivers/media/platform/vivid/vivid-cec.c
drivers/media/platform/vivid/vivid-core.c
drivers/media/radio/dsbr100.c
drivers/media/radio/radio-ma901.c
drivers/media/radio/radio-mr800.c
drivers/media/radio/si470x/radio-si470x-common.c
drivers/media/radio/wl128x/fmdrv_v4l2.c
drivers/media/usb/au0828/au0828-video.c
drivers/media/usb/cpia2/cpia2_v4l.c
drivers/media/usb/cx231xx/cx231xx-audio.c
drivers/media/usb/cx231xx/cx231xx-video.c
drivers/media/usb/em28xx/em28xx-audio.c
drivers/media/usb/em28xx/em28xx-i2c.c
drivers/media/usb/em28xx/em28xx-video.c
drivers/media/usb/hdpvr/hdpvr-video.c
drivers/media/usb/pulse8-cec/pulse8-cec.c
drivers/media/usb/pwc/pwc-if.c
drivers/media/usb/pwc/pwc-v4l.c
drivers/media/usb/rainshadow-cec/rainshadow-cec.c
drivers/media/usb/stk1160/stk1160-i2c.c
drivers/media/usb/stk1160/stk1160-v4l.c
drivers/media/usb/stkwebcam/stk-webcam.c
drivers/media/usb/tm6000/tm6000-alsa.c
drivers/media/usb/tm6000/tm6000-video.c
drivers/media/usb/ttusb-budget/dvb-ttusb-budget.c
drivers/media/usb/usbvision/usbvision-video.c
drivers/media/usb/uvc/uvc_driver.c
drivers/media/usb/zr364xx/zr364xx.c
drivers/staging/media/davinci_vpfe/vpfe_mc_capture.c
drivers/staging/media/imx/imx6-mipi-csi2.c
drivers/staging/media/zoran/zoran_card.c

index 2a5c4b113f89bd3ef08f4d78129ebc00d0b4713e..f90aa8109663195b319c8b930b73f1baf9283ce1 100644 (file)
@@ -451,7 +451,7 @@ static int vidioc_querycap(struct file *file, void *fh, struct v4l2_capability *
        struct video_device *vdev = video_devdata(file);
        struct saa7146_dev *dev = ((struct saa7146_fh *)fh)->dev;
 
-       strcpy((char *)cap->driver, "saa7146 v4l2");
+       strscpy((char *)cap->driver, "saa7146 v4l2", sizeof(cap->driver));
        strscpy((char *)cap->card, dev->ext->name, sizeof(cap->card));
        sprintf((char *)cap->bus_info, "PCI:%s", pci_name(dev->pci));
        cap->device_caps =
index c4e7ebfe4d2955c9d9eb8b0cd55e1302269d7f4b..961207cf09eb489317630b3edcd470fec189a1b5 100644 (file)
@@ -2422,7 +2422,7 @@ static int dvb_frontend_handle_ioctl(struct file *file,
                struct dvb_frontend_info *info = parg;
                memset(info, 0, sizeof(*info));
 
-               strcpy(info->name, fe->ops.info.name);
+               strscpy(info->name, fe->ops.info.name, sizeof(info->name));
                info->symbol_rate_min = fe->ops.info.symbol_rate_min;
                info->symbol_rate_max = fe->ops.info.symbol_rate_max;
                info->symbol_rate_tolerance = fe->ops.info.symbol_rate_tolerance;
index aad07adda37dff25c605e3f1aeb1011c83b17843..03e74a729168c31e51fddf40c42d3826ba75ca05 100644 (file)
@@ -815,17 +815,20 @@ struct dvb_frontend *mt312_attach(const struct mt312_config *config,
 
        switch (state->id) {
        case ID_VP310:
-               strcpy(state->frontend.ops.info.name, "Zarlink VP310 DVB-S");
+               strscpy(state->frontend.ops.info.name, "Zarlink VP310 DVB-S",
+                       sizeof(state->frontend.ops.info.name));
                state->xtal = MT312_PLL_CLK;
                state->freq_mult = 9;
                break;
        case ID_MT312:
-               strcpy(state->frontend.ops.info.name, "Zarlink MT312 DVB-S");
+               strscpy(state->frontend.ops.info.name, "Zarlink MT312 DVB-S",
+                       sizeof(state->frontend.ops.info.name));
                state->xtal = MT312_PLL_CLK;
                state->freq_mult = 6;
                break;
        case ID_ZL10313:
-               strcpy(state->frontend.ops.info.name, "Zarlink ZL10313 DVB-S");
+               strscpy(state->frontend.ops.info.name, "Zarlink ZL10313 DVB-S",
+                       sizeof(state->frontend.ops.info.name));
                state->xtal = MT312_PLL_CLK_10_111;
                state->freq_mult = 9;
                break;
index 6293bd920fa613aae8f7f629688a71283ca299d2..333e4a1da13bd5f673305f082c58f22325817c23 100644 (file)
@@ -288,8 +288,9 @@ struct dvb_frontend *zl10039_attach(struct dvb_frontend *fe,
        state->id = state->id & 0x0f;
        switch (state->id) {
        case ID_ZL10039:
-               strcpy(fe->ops.tuner_ops.info.name,
-                       "Zarlink ZL10039 DVB-S tuner");
+               strscpy(fe->ops.tuner_ops.info.name,
+                       "Zarlink ZL10039 DVB-S tuner",
+                       sizeof(fe->ops.tuner_ops.info.name));
                break;
        default:
                dprintk("Chip ID=%x does not match a known type\n", state->id);
index 69087ae6c1d00d347cdfc2e05c518845e7b434d5..683957885ac43650d534e6ab1633f37edc0f8fd0 100644 (file)
@@ -247,7 +247,7 @@ void fdtv_frontend_init(struct firedtv *fdtv, const char *name)
                dev_err(fdtv->device, "no frontend for model type %d\n",
                        fdtv->type);
        }
-       strcpy(fi->name, name);
+       strscpy(fi->name, name, sizeof(fi->name));
 
        fdtv->fe.dvb = &fdtv->adapter;
        fdtv->fe.sec_priv = fdtv;
index 034ebf7540070074f67dace1ff05b269252090d6..907323f0ca3b63b6b616a3264dab9b8b0f782d52 100644 (file)
@@ -317,7 +317,7 @@ static int ad5820_probe(struct i2c_client *client,
        v4l2_i2c_subdev_init(&coil->subdev, client, &ad5820_ops);
        coil->subdev.flags |= V4L2_SUBDEV_FL_HAS_DEVNODE;
        coil->subdev.internal_ops = &ad5820_internal_ops;
-       strcpy(coil->subdev.name, "ad5820 focus");
+       strscpy(coil->subdev.name, "ad5820 focus", sizeof(coil->subdev.name));
 
        ret = media_entity_pads_init(&coil->subdev.entity, 0, NULL);
        if (ret < 0)
index 49c6644cbba777eaa2b03c182d9e1f660abb6ce5..f122f03bd6b79adeb6efbeb88656d785f1db29d1 100644 (file)
@@ -362,7 +362,8 @@ static int lm3560_subdev_init(struct lm3560_flash *flash,
 
        v4l2_i2c_subdev_init(&flash->subdev_led[led_no], client, &lm3560_ops);
        flash->subdev_led[led_no].flags |= V4L2_SUBDEV_FL_HAS_DEVNODE;
-       strcpy(flash->subdev_led[led_no].name, led_name);
+       strscpy(flash->subdev_led[led_no].name, led_name,
+               sizeof(flash->subdev_led[led_no].name));
        rval = lm3560_init_controls(flash, led_no);
        if (rval)
                goto err_out;
index 7e9967af36ecd36a74dff0bc012bc2a2bed8fb72..12ef2653987b8c37a22338a0003d95828d4fa1e5 100644 (file)
@@ -278,7 +278,8 @@ static int lm3646_subdev_init(struct lm3646_flash *flash)
 
        v4l2_i2c_subdev_init(&flash->subdev_led, client, &lm3646_ops);
        flash->subdev_led.flags |= V4L2_SUBDEV_FL_HAS_DEVNODE;
-       strcpy(flash->subdev_led.name, LM3646_NAME);
+       strscpy(flash->subdev_led.name, LM3646_NAME,
+               sizeof(flash->subdev_led.name));
        rval = lm3646_init_controls(flash);
        if (rval)
                goto err_out;
index 9ca9b39970736cf91ccedeb093b7870acaf0e3fb..21ca5186f9ed569aa804573f039b5bda4155b568 100644 (file)
@@ -1698,7 +1698,7 @@ static int s5c73m3_probe(struct i2c_client *client,
                return ret;
 
        v4l2_i2c_subdev_init(oif_sd, client, &oif_subdev_ops);
-       strcpy(oif_sd->name, "S5C73M3-OIF");
+       strscpy(oif_sd->name, "S5C73M3-OIF", sizeof(oif_sd->name));
 
        oif_sd->internal_ops = &oif_internal_ops;
        oif_sd->flags |= V4L2_SUBDEV_FL_HAS_DEVNODE;
index 2a4882cddc51950a4dabf8aa2a99784904d9d1cf..344666293f7dc167ee5f82f72ce18b7649b7d7bb 100644 (file)
@@ -703,7 +703,7 @@ static int sr030pc30_probe(struct i2c_client *client,
                return -ENOMEM;
 
        sd = &info->sd;
-       strcpy(sd->name, MODULE_NAME);
+       strscpy(sd->name, MODULE_NAME, sizeof(sd->name));
        info->pdata = client->dev.platform_data;
 
        v4l2_i2c_subdev_init(sd, client, &sr030pc30_ops);
index 95045448a1125cda5b448d7e423d773e32ec799d..413bf287547cb5d0bd1957d7a1582aa7e464279a 100644 (file)
@@ -2782,7 +2782,7 @@ static int bttv_g_tuner(struct file *file, void *priv,
        t->rxsubchans = V4L2_TUNER_SUB_MONO;
        t->capability = V4L2_TUNER_CAP_NORM;
        bttv_call_all(btv, tuner, g_tuner, t);
-       strcpy(t->name, "Television");
+       strscpy(t->name, "Television", sizeof(t->name));
        t->type       = V4L2_TUNER_ANALOG_TV;
        if (btread(BT848_DSTATUS)&BT848_DSTATUS_HLOC)
                t->signal = 0xffff;
@@ -3257,7 +3257,7 @@ static int radio_g_tuner(struct file *file, void *priv, struct v4l2_tuner *t)
 
        if (0 != t->index)
                return -EINVAL;
-       strcpy(t->name, "Radio");
+       strscpy(t->name, "Radio", sizeof(t->name));
        t->type = V4L2_TUNER_RADIO;
        radio_enable(btv);
 
index 8579de5bb61b376d61ada537ff5c9292aedcba28..3083434bb6369c865db3c1190ed32e6573c62fe2 100644 (file)
@@ -1280,7 +1280,7 @@ static int vidioc_g_tuner(struct file *file, void *priv,
                return -EINVAL;
        if (0 != t->index)
                return -EINVAL;
-       strcpy(t->name, "Television");
+       strscpy(t->name, "Television", sizeof(t->name));
        call_all(dev, tuner, g_tuner, t);
 
        dprintk(1, "VIDIOC_G_TUNER: tuner type %d\n", t->type);
index db1e8ff35474a9d3875b1f01d5243d878a3e6cf6..ee9d329c40389e7094ccd26940ac1ad7ceb84ad9 100644 (file)
@@ -526,7 +526,7 @@ static int snd_cx23885_pcm(struct cx23885_audio_dev *chip, int device,
        if (err < 0)
                return err;
        pcm->private_data = chip;
-       strcpy(pcm->name, name);
+       strscpy(pcm->name, name, sizeof(pcm->name));
        snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &snd_cx23885_pcm_ops);
 
        return 0;
@@ -571,7 +571,7 @@ struct cx23885_audio_dev *cx23885_audio_register(struct cx23885_dev *dev)
        if (err < 0)
                goto error;
 
-       strcpy(card->driver, "CX23885");
+       strscpy(card->driver, "CX23885", sizeof(card->driver));
        sprintf(card->shortname, "Conexant CX23885");
        sprintf(card->longname, "%s at %s", card->shortname, dev->name);
 
index b5ac7a6a9a62c95d07618ebb172ddd9be2e10379..92d32a733f1b4a32b4ef0b3dc6c49b838001d788 100644 (file)
@@ -639,7 +639,7 @@ static int vidioc_querycap(struct file *file, void  *priv,
        struct cx23885_dev *dev = video_drvdata(file);
        struct video_device *vdev = video_devdata(file);
 
-       strcpy(cap->driver, "cx23885");
+       strscpy(cap->driver, "cx23885", sizeof(cap->driver));
        strscpy(cap->card, cx23885_boards[dev->board].name,
                sizeof(cap->card));
        sprintf(cap->bus_info, "PCIe:%s", pci_name(dev->pci));
@@ -731,7 +731,7 @@ int cx23885_enum_input(struct cx23885_dev *dev, struct v4l2_input *i)
 
        i->index = n;
        i->type  = V4L2_INPUT_TYPE_CAMERA;
-       strcpy(i->name, iname[INPUT(n)->type]);
+       strscpy(i->name, iname[INPUT(n)->type], sizeof(i->name));
        i->std = CX23885_NORMS;
        if ((CX23885_VMUX_TELEVISION == INPUT(n)->type) ||
                (CX23885_VMUX_CABLE == INPUT(n)->type)) {
@@ -828,7 +828,7 @@ static int cx23885_query_audinput(struct file *file, void *priv,
 
        memset(i, 0, sizeof(*i));
        i->index = n;
-       strcpy(i->name, iname[n]);
+       strscpy(i->name, iname[n], sizeof(i->name));
        i->capability = V4L2_AUDCAP_STEREO;
        return 0;
 
@@ -887,7 +887,7 @@ static int vidioc_g_tuner(struct file *file, void *priv,
        if (0 != t->index)
                return -EINVAL;
 
-       strcpy(t->name, "Television");
+       strscpy(t->name, "Television", sizeof(t->name));
 
        call_all(dev, tuner, g_tuner, t);
        return 0;
@@ -1186,7 +1186,8 @@ int cx23885_video_register(struct cx23885_dev *dev)
 
        /* Initialize VBI template */
        cx23885_vbi_template = cx23885_video_template;
-       strcpy(cx23885_vbi_template.name, "cx23885-vbi");
+       strscpy(cx23885_vbi_template.name, "cx23885-vbi",
+               sizeof(cx23885_vbi_template.name));
 
        dev->tvnorm = V4L2_STD_NTSC_M;
        dev->fmt = format_by_fourcc(V4L2_PIX_FMT_YUYV);
index ef6380651c10b133504e86d51ebe3199db8602c2..0a6c90e925572747e35ef1e4847cb66a1f2cbac5 100644 (file)
@@ -674,7 +674,7 @@ static int snd_cx25821_pcm(struct cx25821_audio_dev *chip, int device,
        }
        pcm->private_data = chip;
        pcm->info_flags = 0;
-       strcpy(pcm->name, name);
+       strscpy(pcm->name, name, sizeof(pcm->name));
        snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &snd_cx25821_pcm_ops);
 
        return 0;
@@ -725,7 +725,7 @@ static int cx25821_audio_initdev(struct cx25821_dev *dev)
                return err;
        }
 
-       strcpy(card->driver, "cx25821");
+       strscpy(card->driver, "cx25821", sizeof(card->driver));
 
        /* Card "creation" */
        chip = card->private_data;
@@ -754,10 +754,10 @@ static int cx25821_audio_initdev(struct cx25821_dev *dev)
                goto error;
        }
 
-       strcpy(card->shortname, "cx25821");
+       strscpy(card->shortname, "cx25821", sizeof(card->shortname));
        sprintf(card->longname, "%s at 0x%lx irq %d", chip->dev->name,
                chip->iobase, chip->irq);
-       strcpy(card->mixername, "CX25821");
+       strscpy(card->mixername, "CX25821", sizeof(card->mixername));
 
        pr_info("%s/%i: ALSA support for cx25821 boards\n", card->driver,
                devno);
index 21607fbb675889b49c73621b66f785a1c3c9c758..3d23c2e64102f7680b7860d5a003b7adec02c12c 100644 (file)
@@ -441,7 +441,7 @@ static int cx25821_vidioc_querycap(struct file *file, void *priv,
                        V4L2_CAP_READWRITE | V4L2_CAP_STREAMING;
        const u32 cap_output = V4L2_CAP_VIDEO_OUTPUT | V4L2_CAP_READWRITE;
 
-       strcpy(cap->driver, "cx25821");
+       strscpy(cap->driver, "cx25821", sizeof(cap->driver));
        strscpy(cap->card, cx25821_boards[dev->board].name, sizeof(cap->card));
        sprintf(cap->bus_info, "PCIe:%s", pci_name(dev->pci));
        if (chan->id >= VID_CHANNEL_NUM)
@@ -486,7 +486,7 @@ static int cx25821_vidioc_enum_input(struct file *file, void *priv,
 
        i->type = V4L2_INPUT_TYPE_CAMERA;
        i->std = CX25821_NORMS;
-       strcpy(i->name, "Composite");
+       strscpy(i->name, "Composite", sizeof(i->name));
        return 0;
 }
 
@@ -534,7 +534,7 @@ static int cx25821_vidioc_enum_output(struct file *file, void *priv,
 
        o->type = V4L2_INPUT_TYPE_CAMERA;
        o->std = CX25821_NORMS;
-       strcpy(o->name, "Composite");
+       strscpy(o->name, "Composite", sizeof(o->name));
        return 0;
 }
 
index 89a65478ae36d4eed134fccbf69a2223c9aae6f2..b683cbe13dee0135a1a111e7e3be99715ef7e629 100644 (file)
@@ -616,7 +616,7 @@ static int snd_cx88_pcm(struct cx88_audio_dev *chip, int device,
        if (err < 0)
                return err;
        pcm->private_data = chip;
-       strcpy(pcm->name, name);
+       strscpy(pcm->name, name, sizeof(pcm->name));
        snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &snd_cx88_pcm_ops);
 
        return 0;
@@ -968,12 +968,12 @@ static int cx88_audio_initdev(struct pci_dev *pci,
                        goto error;
        }
 
-       strcpy(card->driver, "CX88x");
+       strscpy(card->driver, "CX88x", sizeof(card->driver));
        sprintf(card->shortname, "Conexant CX%x", pci->device);
        sprintf(card->longname, "%s at %#llx",
                card->shortname,
                (unsigned long long)pci_resource_start(pci, 0));
-       strcpy(card->mixername, "CX88");
+       strscpy(card->mixername, "CX88", sizeof(card->mixername));
 
        dprintk(0, "%s/%i: ALSA support for cx2388x boards\n",
                card->driver, devno);
index cf4e926cc3889e8e84fd114bad1683e60274a058..199756547f03b13c327913b9c904d854d383ed02 100644 (file)
@@ -803,7 +803,7 @@ static int vidioc_querycap(struct file *file, void  *priv,
        struct cx8802_dev *dev = video_drvdata(file);
        struct cx88_core *core = dev->core;
 
-       strcpy(cap->driver, "cx88_blackbird");
+       strscpy(cap->driver, "cx88_blackbird", sizeof(cap->driver));
        sprintf(cap->bus_info, "PCI:%s", pci_name(dev->pci));
        return cx88_querycap(file, core, cap);
 }
@@ -995,7 +995,7 @@ static int vidioc_g_tuner(struct file *file, void *priv,
        if (t->index != 0)
                return -EINVAL;
 
-       strcpy(t->name, "Television");
+       strscpy(t->name, "Television", sizeof(t->name));
        t->capability = V4L2_TUNER_CAP_NORM;
        t->rangehigh  = 0xffffffffUL;
        call_all(core, tuner, g_tuner, t);
index 07e1483e987d506a9145838a9192af6355c0f7dc..382af90fd4a900c6e72f203adf212d664079a1aa 100644 (file)
@@ -3693,7 +3693,7 @@ struct cx88_core *cx88_core_create(struct pci_dev *pci, int nr)
        core->height  = 240;
        core->field   = V4L2_FIELD_INTERLACED;
 
-       strcpy(core->v4l2_dev.name, core->name);
+       strscpy(core->v4l2_dev.name, core->name, sizeof(core->v4l2_dev.name));
        if (v4l2_device_register(NULL, &core->v4l2_dev)) {
                kfree(core);
                return NULL;
index f5d0624023da39da0c08c8126eef50f4ffbb327b..df4e7a0686e0b8973755fcac97f8b8ef26fba9f3 100644 (file)
@@ -842,7 +842,7 @@ static int vidioc_querycap(struct file *file, void  *priv,
        struct cx8800_dev *dev = video_drvdata(file);
        struct cx88_core *core = dev->core;
 
-       strcpy(cap->driver, "cx8800");
+       strscpy(cap->driver, "cx8800", sizeof(cap->driver));
        sprintf(cap->bus_info, "PCI:%s", pci_name(dev->pci));
        return cx88_querycap(file, core, cap);
 }
@@ -897,7 +897,7 @@ int cx88_enum_input(struct cx88_core  *core, struct v4l2_input *i)
        if (!INPUT(n).type)
                return -EINVAL;
        i->type  = V4L2_INPUT_TYPE_CAMERA;
-       strcpy(i->name, iname[INPUT(n).type]);
+       strscpy(i->name, iname[INPUT(n).type], sizeof(i->name));
        if ((INPUT(n).type == CX88_VMUX_TELEVISION) ||
            (INPUT(n).type == CX88_VMUX_CABLE))
                i->type = V4L2_INPUT_TYPE_TUNER;
@@ -952,7 +952,7 @@ static int vidioc_g_tuner(struct file *file, void *priv,
        if (t->index != 0)
                return -EINVAL;
 
-       strcpy(t->name, "Television");
+       strscpy(t->name, "Television", sizeof(t->name));
        t->capability = V4L2_TUNER_CAP_NORM;
        t->rangehigh  = 0xffffffffUL;
        call_all(core, tuner, g_tuner, t);
@@ -1065,7 +1065,7 @@ static int radio_g_tuner(struct file *file, void *priv,
        if (unlikely(t->index > 0))
                return -EINVAL;
 
-       strcpy(t->name, "Radio");
+       strscpy(t->name, "Radio", sizeof(t->name));
 
        call_all(core, tuner, g_tuner, t);
        return 0;
index 1ddb0576fb7b1af37d8c681d925df6260bc2ff4a..a84c8270ea13e82de70a1467fd0e2fba767ed7f7 100644 (file)
@@ -1046,7 +1046,7 @@ static int dm1105_probe(struct pci_dev *pdev,
 
        /* i2c */
        i2c_set_adapdata(&dev->i2c_adap, dev);
-       strcpy(dev->i2c_adap.name, DRIVER_NAME);
+       strscpy(dev->i2c_adap.name, DRIVER_NAME, sizeof(dev->i2c_adap.name));
        dev->i2c_adap.owner = THIS_MODULE;
        dev->i2c_adap.dev.parent = &pdev->dev;
        dev->i2c_adap.algo = &dm1105_algo;
@@ -1057,7 +1057,8 @@ static int dm1105_probe(struct pci_dev *pdev,
                goto err_dm1105_hw_exit;
 
        i2c_set_adapdata(&dev->i2c_bb_adap, dev);
-       strcpy(dev->i2c_bb_adap.name, DM1105_I2C_GPIO_NAME);
+       strscpy(dev->i2c_bb_adap.name, DM1105_I2C_GPIO_NAME,
+               sizeof(dev->i2c_bb_adap.name));
        dev->i2c_bb_adap.owner = THIS_MODULE;
        dev->i2c_bb_adap.dev.parent = &pdev->dev;
        dev->i2c_bb_adap.algo_data = &dev->i2c_bit;
index bf6e1621ad6b3d7dad98d40f52fd87f5fde97b13..17d69bd5d7f112f970465e8511602eaa8b8100ac 100644 (file)
@@ -307,8 +307,8 @@ static int dt3155_querycap(struct file *filp, void *p,
 {
        struct dt3155_priv *pd = video_drvdata(filp);
 
-       strcpy(cap->driver, DT3155_NAME);
-       strcpy(cap->card, DT3155_NAME " frame grabber");
+       strscpy(cap->driver, DT3155_NAME, sizeof(cap->driver));
+       strscpy(cap->card, DT3155_NAME " frame grabber", sizeof(cap->card));
        sprintf(cap->bus_info, "PCI:%s", pci_name(pd->pdev));
        cap->device_caps = V4L2_CAP_VIDEO_CAPTURE |
                V4L2_CAP_STREAMING | V4L2_CAP_READWRITE;
@@ -322,7 +322,7 @@ static int dt3155_enum_fmt_vid_cap(struct file *filp,
        if (f->index)
                return -EINVAL;
        f->pixelformat = V4L2_PIX_FMT_GREY;
-       strcpy(f->description, "8-bit Greyscale");
+       strscpy(f->description, "8-bit Greyscale", sizeof(f->description));
        return 0;
 }
 
index 8001d3e9134e440836fdf39b5b3624fd75b5ebe7..7285edcdd3232d6cacf8077dcc757ae991391f2e 100644 (file)
@@ -1019,8 +1019,8 @@ static int meyeioc_stilljcapt(int *len)
 static int vidioc_querycap(struct file *file, void *fh,
                                struct v4l2_capability *cap)
 {
-       strcpy(cap->driver, "meye");
-       strcpy(cap->card, "meye");
+       strscpy(cap->driver, "meye", sizeof(cap->driver));
+       strscpy(cap->card, "meye", sizeof(cap->card));
        sprintf(cap->bus_info, "PCI:%s", pci_name(meye.mchip_dev));
 
        cap->device_caps = V4L2_CAP_VIDEO_CAPTURE |
@@ -1035,7 +1035,7 @@ static int vidioc_enum_input(struct file *file, void *fh, struct v4l2_input *i)
        if (i->index != 0)
                return -EINVAL;
 
-       strcpy(i->name, "Camera");
+       strscpy(i->name, "Camera", sizeof(i->name));
        i->type = V4L2_INPUT_TYPE_CAMERA;
 
        return 0;
@@ -1118,12 +1118,12 @@ static int vidioc_enum_fmt_vid_cap(struct file *file, void *fh,
        if (f->index == 0) {
                /* standard YUV 422 capture */
                f->flags = 0;
-               strcpy(f->description, "YUV422");
+               strscpy(f->description, "YUV422", sizeof(f->description));
                f->pixelformat = V4L2_PIX_FMT_YUYV;
        } else {
                /* compressed MJPEG capture */
                f->flags = V4L2_FMT_FLAG_COMPRESSED;
-               strcpy(f->description, "MJPEG");
+               strscpy(f->description, "MJPEG", sizeof(f->description));
                f->pixelformat = V4L2_PIX_FMT_MJPEG;
        }
 
index 092d46c2a3a9471f1bb57c6d33c495b9268e2bfb..02a06f6c97f85cdeb3b279f38eb3a65725fc3205 100644 (file)
@@ -161,7 +161,7 @@ int ngene_i2c_init(struct ngene *dev, int dev_nr)
 
        i2c_set_adapdata(adap, &(dev->channel[dev_nr]));
 
-       strcpy(adap->name, "nGene");
+       strscpy(adap->name, "nGene", sizeof(adap->name));
 
        adap->algo = &ngene_i2c_algo;
        adap->algo_data = (void *)&(dev->channel[dev_nr]);
index 5e6fe686f420b5b73fb01bd0f8977bb58ac8c0e6..872c796621d20ad922f0eeca16ca39c463fe9ac7 100644 (file)
@@ -633,7 +633,7 @@ static int pluto2_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
 
        /* i2c */
        i2c_set_adapdata(&pluto->i2c_adap, pluto);
-       strcpy(pluto->i2c_adap.name, DRIVER_NAME);
+       strscpy(pluto->i2c_adap.name, DRIVER_NAME, sizeof(pluto->i2c_adap.name));
        pluto->i2c_adap.owner = THIS_MODULE;
        pluto->i2c_adap.dev.parent = &pdev->dev;
        pluto->i2c_adap.algo_data = &pluto->i2c_bit;
index 7f878fc41b7e68dad6be30cfa8a3565c4e6a6704..f4b8030e236952858d8242fdf2fc90b4f0b7ff85 100644 (file)
@@ -1354,7 +1354,7 @@ static int pt1_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
        i2c_adap->algo = &pt1_i2c_algo;
        i2c_adap->algo_data = NULL;
        i2c_adap->dev.parent = &pdev->dev;
-       strcpy(i2c_adap->name, DRIVER_NAME);
+       strscpy(i2c_adap->name, DRIVER_NAME, sizeof(i2c_adap->name));
        i2c_set_adapdata(i2c_adap, pt1);
        ret = i2c_add_adapter(i2c_adap);
        if (ret < 0)
index b90cfde6e3016bb2d63d23dafe8f99da6015b1d9..dc9cdaaee1fb80923b04e89d6ef25c185601acb9 100644 (file)
@@ -901,7 +901,7 @@ static int snd_card_saa7134_pcm(snd_card_saa7134_t *saa7134, int device)
        snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &snd_card_saa7134_capture_ops);
        pcm->private_data = saa7134;
        pcm->info_flags = 0;
-       strcpy(pcm->name, "SAA7134 PCM");
+       strscpy(pcm->name, "SAA7134 PCM", sizeof(pcm->name));
        return 0;
 }
 
@@ -1074,7 +1074,7 @@ static int snd_card_saa7134_new_mixer(snd_card_saa7134_t * chip)
        unsigned int idx;
        int err, addr;
 
-       strcpy(card->mixername, "SAA7134 Mixer");
+       strscpy(card->mixername, "SAA7134 Mixer", sizeof(card->mixername));
 
        for (idx = 0; idx < ARRAY_SIZE(snd_saa7134_volume_controls); idx++) {
                kcontrol = snd_ctl_new1(&snd_saa7134_volume_controls[idx],
@@ -1138,7 +1138,7 @@ static int alsa_card_saa7134_create(struct saa7134_dev *dev, int devnum)
        if (err < 0)
                return err;
 
-       strcpy(card->driver, "SAA7134");
+       strscpy(card->driver, "SAA7134", sizeof(card->driver));
 
        /* Card "creation" */
 
@@ -1178,7 +1178,7 @@ static int alsa_card_saa7134_create(struct saa7134_dev *dev, int devnum)
 
        /* End of "creation" */
 
-       strcpy(card->shortname, "SAA7134");
+       strscpy(card->shortname, "SAA7134", sizeof(card->shortname));
        sprintf(card->longname, "%s at 0x%lx irq %d",
                chip->dev->name, chip->iobase, chip->irq);
 
index cf1e526de56ac0fadd1c75b05b964481d8ec3e09..51af3310654c2d12e7e6dc6c8d59c588490c0503 100644 (file)
@@ -437,7 +437,7 @@ int saa7134_i2c_register(struct saa7134_dev *dev)
 {
        dev->i2c_adap = saa7134_adap_template;
        dev->i2c_adap.dev.parent = &dev->pci->dev;
-       strcpy(dev->i2c_adap.name,dev->name);
+       strscpy(dev->i2c_adap.name, dev->name, sizeof(dev->i2c_adap.name));
        dev->i2c_adap.algo_data = dev;
        i2c_set_adapdata(&dev->i2c_adap, &dev->v4l2_dev);
        i2c_add_adapter(&dev->i2c_adap);
index b41de940a1ee07f858d7d9f44c0cde1fd8ab3ab5..1a22ae7cbdd95da9d9d41a50452f05dc825dc55e 100644 (file)
@@ -1445,7 +1445,8 @@ int saa7134_enum_input(struct file *file, void *priv, struct v4l2_input *i)
        if (card_in(dev, i->index).type == SAA7134_NO_INPUT)
                return -EINVAL;
        i->index = n;
-       strcpy(i->name, saa7134_input_name[card_in(dev, n).type]);
+       strscpy(i->name, saa7134_input_name[card_in(dev, n).type],
+               sizeof(i->name));
        switch (card_in(dev, n).type) {
        case SAA7134_INPUT_TV:
        case SAA7134_INPUT_TV_MONO:
@@ -1502,7 +1503,7 @@ int saa7134_querycap(struct file *file, void *priv,
 
        unsigned int tuner_type = dev->tuner_type;
 
-       strcpy(cap->driver, "saa7134");
+       strscpy(cap->driver, "saa7134", sizeof(cap->driver));
        strscpy(cap->card, saa7134_boards[dev->board].name,
                sizeof(cap->card));
        sprintf(cap->bus_info, "PCI:%s", pci_name(dev->pci));
@@ -1747,7 +1748,7 @@ int saa7134_g_tuner(struct file *file, void *priv,
        if (n == SAA7134_INPUT_MAX)
                return -EINVAL;
        if (card_in(dev, n).type != SAA7134_NO_INPUT) {
-               strcpy(t->name, "Television");
+               strscpy(t->name, "Television", sizeof(t->name));
                t->type = V4L2_TUNER_ANALOG_TV;
                saa_call_all(dev, tuner, g_tuner, t);
                t->capability = V4L2_TUNER_CAP_NORM |
@@ -1939,7 +1940,7 @@ static int radio_g_tuner(struct file *file, void *priv,
        if (0 != t->index)
                return -EINVAL;
 
-       strcpy(t->name, "Radio");
+       strscpy(t->name, "Radio", sizeof(t->name));
 
        saa_call_all(dev, tuner, g_tuner, t);
        t->audmode &= V4L2_TUNER_MODE_MONO | V4L2_TUNER_MODE_STEREO;
index d697e1ad929c2d8e765feb15f136563b103bef05..f33349e163591ab8867836946bde988eb552d3f3 100644 (file)
@@ -179,7 +179,7 @@ static void saa7164_histogram_reset(struct saa7164_histogram *hg, char *name)
        int i;
 
        memset(hg, 0, sizeof(struct saa7164_histogram));
-       strcpy(hg->name, name);
+       strscpy(hg->name, name, sizeof(hg->name));
 
        /* First 30ms x 1ms */
        for (i = 0; i < 30; i++)
index 50161921e4e7455490834a86e4ffa8caf1941deb..adec2bab8352daedf0016ceef827cb6c6a909ecd 100644 (file)
@@ -258,7 +258,7 @@ int saa7164_enum_input(struct file *file, void *priv, struct v4l2_input *i)
        if (i->index >= 7)
                return -EINVAL;
 
-       strcpy(i->name, inputs[i->index]);
+       strscpy(i->name, inputs[i->index], sizeof(i->name));
 
        if (i->index == 0)
                i->type = V4L2_INPUT_TYPE_TUNER;
@@ -325,7 +325,7 @@ int saa7164_g_tuner(struct file *file, void *priv, struct v4l2_tuner *t)
        if (0 != t->index)
                return -EINVAL;
 
-       strcpy(t->name, "tuner");
+       strscpy(t->name, "tuner", sizeof(t->name));
        t->capability = V4L2_TUNER_CAP_NORM | V4L2_TUNER_CAP_STEREO;
        t->rangelow = SAA7164_TV_MIN_FREQ;
        t->rangehigh = SAA7164_TV_MAX_FREQ;
@@ -497,7 +497,7 @@ static int vidioc_querycap(struct file *file, void  *priv,
        struct saa7164_port *port = fh->port;
        struct saa7164_dev *dev = port->dev;
 
-       strcpy(cap->driver, dev->name);
+       strscpy(cap->driver, dev->name, sizeof(cap->driver));
        strscpy(cap->card, saa7164_boards[dev->board].name,
                sizeof(cap->card));
        sprintf(cap->bus_info, "PCI:%s", pci_name(dev->pci));
index 17b7cabf9a1f22e672203ac502f47b6b9c7aef60..841c7e94405d28c6cb701cd15dc87084c4ed5994 100644 (file)
@@ -208,7 +208,7 @@ static int vidioc_querycap(struct file *file, void  *priv,
        struct saa7164_port *port = fh->port;
        struct saa7164_dev *dev = port->dev;
 
-       strcpy(cap->driver, dev->name);
+       strscpy(cap->driver, dev->name, sizeof(cap->driver));
        strscpy(cap->card, saa7164_boards[dev->board].name,
                sizeof(cap->card));
        sprintf(cap->bus_info, "PCI:%s", pci_name(dev->pci));
index 4c2da27fee4b8bf232da2fa90e2e0d67e6bd8308..4d5ddbcb35149e5bdb059470b2ddc7a843f23249 100644 (file)
@@ -191,7 +191,7 @@ static int smi_i2c_init(struct smi_dev *dev)
        /* i2c bus 0 */
        smi_i2c_cfg(dev, I2C_A_SW_CTL);
        i2c_set_adapdata(&dev->i2c_bus[0], dev);
-       strcpy(dev->i2c_bus[0].name, "SMI-I2C0");
+       strscpy(dev->i2c_bus[0].name, "SMI-I2C0", sizeof(dev->i2c_bus[0].name));
        dev->i2c_bus[0].owner = THIS_MODULE;
        dev->i2c_bus[0].dev.parent = &dev->pci_dev->dev;
        dev->i2c_bus[0].algo_data = &dev->i2c_bit[0];
@@ -213,7 +213,7 @@ static int smi_i2c_init(struct smi_dev *dev)
        /* i2c bus 1 */
        smi_i2c_cfg(dev, I2C_B_SW_CTL);
        i2c_set_adapdata(&dev->i2c_bus[1], dev);
-       strcpy(dev->i2c_bus[1].name, "SMI-I2C1");
+       strscpy(dev->i2c_bus[1].name, "SMI-I2C1", sizeof(dev->i2c_bus[1].name));
        dev->i2c_bus[1].owner = THIS_MODULE;
        dev->i2c_bus[1].dev.parent = &dev->pci_dev->dev;
        dev->i2c_bus[1].algo_data = &dev->i2c_bit[1];
index 2ac33b5cc45466ba2455455343aefc93f835f2e9..2cc05a9d57ac17e854533c1a8d68e5c6e5de1e04 100644 (file)
@@ -354,7 +354,7 @@ static int solo_snd_pcm_init(struct solo_dev *solo_dev)
 
        snd_pcm_chip(pcm) = solo_dev;
        pcm->info_flags = 0;
-       strcpy(pcm->name, card->shortname);
+       strscpy(pcm->name, card->shortname, sizeof(pcm->name));
 
        for (i = 0, ss = pcm->streams[SNDRV_PCM_STREAM_CAPTURE].substream;
             ss; ss = ss->next, i++)
@@ -394,8 +394,8 @@ int solo_g723_init(struct solo_dev *solo_dev)
 
        card = solo_dev->snd_card;
 
-       strcpy(card->driver, SOLO6X10_NAME);
-       strcpy(card->shortname, "SOLO-6x10 Audio");
+       strscpy(card->driver, SOLO6X10_NAME, sizeof(card->driver));
+       strscpy(card->shortname, "SOLO-6x10 Audio", sizeof(card->shortname));
        sprintf(card->longname, "%s on %s IRQ %d", card->shortname,
                pci_name(solo_dev->pdev), solo_dev->pdev->irq);
 
@@ -404,7 +404,7 @@ int solo_g723_init(struct solo_dev *solo_dev)
                goto snd_error;
 
        /* Mixer controls */
-       strcpy(card->mixername, "SOLO-6x10");
+       strscpy(card->mixername, "SOLO-6x10", sizeof(card->mixername));
        kctl = snd_solo_capture_volume;
        kctl.count = solo_dev->nr_chans;
 
index 25f9f2ebff1da3ace2e4c1192ba83ec0fe66b2f3..9d27e7463070f3bc3821dfd1b91a0b68144528a0 100644 (file)
@@ -775,7 +775,7 @@ static int solo_enc_querycap(struct file *file, void  *priv,
        struct solo_enc_dev *solo_enc = video_drvdata(file);
        struct solo_dev *solo_dev = solo_enc->solo_dev;
 
-       strcpy(cap->driver, SOLO6X10_NAME);
+       strscpy(cap->driver, SOLO6X10_NAME, sizeof(cap->driver));
        snprintf(cap->card, sizeof(cap->card), "Softlogic 6x10 Enc %d",
                 solo_enc->ch);
        snprintf(cap->bus_info, sizeof(cap->bus_info), "PCI:%s",
@@ -834,17 +834,18 @@ static int solo_enc_enum_fmt_cap(struct file *file, void *priv,
                switch (dev_type) {
                case SOLO_DEV_6010:
                        f->pixelformat = V4L2_PIX_FMT_MPEG4;
-                       strcpy(f->description, "MPEG-4 part 2");
+                       strscpy(f->description, "MPEG-4 part 2",
+                               sizeof(f->description));
                        break;
                case SOLO_DEV_6110:
                        f->pixelformat = V4L2_PIX_FMT_H264;
-                       strcpy(f->description, "H.264");
+                       strscpy(f->description, "H.264", sizeof(f->description));
                        break;
                }
                break;
        case 1:
                f->pixelformat = V4L2_PIX_FMT_MJPEG;
-               strcpy(f->description, "MJPEG");
+               strscpy(f->description, "MJPEG", sizeof(f->description));
                break;
        default:
                return -EINVAL;
@@ -1126,7 +1127,8 @@ static int solo_s_ctrl(struct v4l2_ctrl *ctrl)
                                        solo_enc->md_thresholds->p_new.p_u16);
                break;
        case V4L2_CID_OSD_TEXT:
-               strcpy(solo_enc->osd_text, ctrl->p_new.p_char);
+               strscpy(solo_enc->osd_text, ctrl->p_new.p_char,
+                       sizeof(solo_enc->osd_text));
                return solo_osd_print(solo_enc);
        default:
                return -EINVAL;
index 351bc434d3a2c553a22afaa02a3fd4d92732bae0..69fc939fd3d9870eeb77e140e4430a5eb41c4423 100644 (file)
@@ -383,8 +383,8 @@ static int solo_querycap(struct file *file, void  *priv,
 {
        struct solo_dev *solo_dev = video_drvdata(file);
 
-       strcpy(cap->driver, SOLO6X10_NAME);
-       strcpy(cap->card, "Softlogic 6x10");
+       strscpy(cap->driver, SOLO6X10_NAME, sizeof(cap->driver));
+       strscpy(cap->card, "Softlogic 6x10", sizeof(cap->card));
        snprintf(cap->bus_info, sizeof(cap->bus_info), "PCI:%s",
                 pci_name(solo_dev->pdev));
        cap->device_caps = V4L2_CAP_VIDEO_CAPTURE |
index 1858efedaf1a42d84935b040086d53e8e5e0ad3b..411177ec4d723ead50634df7d94a5d570d5b46f4 100644 (file)
@@ -419,8 +419,8 @@ static int vidioc_querycap(struct file *file, void *priv,
 {
        struct sta2x11_vip *vip = video_drvdata(file);
 
-       strcpy(cap->driver, KBUILD_MODNAME);
-       strcpy(cap->card, KBUILD_MODNAME);
+       strscpy(cap->driver, KBUILD_MODNAME, sizeof(cap->driver));
+       strscpy(cap->card, KBUILD_MODNAME, sizeof(cap->card));
        snprintf(cap->bus_info, sizeof(cap->bus_info), "PCI:%s",
                 pci_name(vip->pdev));
        cap->device_caps = V4L2_CAP_VIDEO_CAPTURE | V4L2_CAP_READWRITE |
@@ -580,7 +580,7 @@ static int vidioc_enum_fmt_vid_cap(struct file *file, void *priv,
        if (f->index != 0)
                return -EINVAL;
 
-       strcpy(f->description, "4:2:2, packed, UYVY");
+       strscpy(f->description, "4:2:2, packed, UYVY", sizeof(f->description));
        f->pixelformat = V4L2_PIX_FMT_UYVY;
        f->flags = 0;
        return 0;
index e4cf42c322840d7fb17e6bbb2e22ca11d141908a..d1fe15365f4a0f9b37d4431aa386dc5d1bda80a7 100644 (file)
@@ -332,7 +332,7 @@ static int vidioc_g_tuner(struct file *file, void *fh, struct v4l2_tuner *t)
                return -EINVAL;
 
        memset(t, 0, sizeof(*t));
-       strcpy((char *)t->name, "Television");
+       strscpy((char *)t->name, "Television", sizeof(t->name));
 
        t->type = V4L2_TUNER_ANALOG_TV;
        t->capability = V4L2_TUNER_CAP_NORM | V4L2_TUNER_CAP_STEREO |
index 505356bde14b08674d8d81b0f8555af96cb9236c..35b696bdb2df043468dd86a4881480925ee532e7 100644 (file)
@@ -508,7 +508,8 @@ int ttpci_budget_init(struct budget *budget, struct saa7146_dev *dev,
                sizeof(budget->i2c_adap.name));
 
        saa7146_i2c_adapter_prepare(dev, &budget->i2c_adap, SAA7146_I2C_BUS_BIT_RATE_120);
-       strcpy(budget->i2c_adap.name, budget->card->name);
+       strscpy(budget->i2c_adap.name, budget->card->name,
+               sizeof(budget->i2c_adap.name));
 
        if (i2c_add_adapter(&budget->i2c_adap) < 0) {
                ret = -ENOMEM;
index ff2b7da90c088694a83f7c908536aebfd5c8a8a1..5a1f3aa4101ae19f6626519b01d8310747514ccb 100644 (file)
@@ -610,7 +610,7 @@ static int tw5864_querycap(struct file *file, void *priv,
 {
        struct tw5864_input *input = video_drvdata(file);
 
-       strcpy(cap->driver, "tw5864");
+       strscpy(cap->driver, "tw5864", sizeof(cap->driver));
        snprintf(cap->card, sizeof(cap->card), "TW5864 Encoder %d",
                 input->nr);
        sprintf(cap->bus_info, "PCI:%s", pci_name(input->root->pci));
index 08e7dd6ecb07a5d6e1c2be858389a3c3bf78e3bc..d3f727045ae8470e9b78f9364492cf79ee943dd6 100644 (file)
@@ -734,7 +734,7 @@ static int tw68_querycap(struct file *file, void  *priv,
 {
        struct tw68_dev *dev = video_drvdata(file);
 
-       strcpy(cap->driver, "tw68");
+       strscpy(cap->driver, "tw68", sizeof(cap->driver));
        strscpy(cap->card, "Techwell Capture Card",
                sizeof(cap->card));
        sprintf(cap->bus_info, "PCI:%s", pci_name(dev->pci));
index 28590cf3770b2e10b4cbd19acfdbc31a7e3bd0a1..cac6aec0ffa72bc82742adbb6e1be849651d3c05 100644 (file)
@@ -2455,7 +2455,8 @@ vpfe_get_pdata(struct platform_device *pdev)
 
                /* we only support camera */
                sdinfo->inputs[0].index = i;
-               strcpy(sdinfo->inputs[0].name, "Camera");
+               strscpy(sdinfo->inputs[0].name, "Camera",
+                       sizeof(sdinfo->inputs[0].name));
                sdinfo->inputs[0].type = V4L2_INPUT_TYPE_CAMERA;
                sdinfo->inputs[0].std = V4L2_STD_ALL;
                sdinfo->inputs[0].capabilities = V4L2_IN_CAP_STD;
index 776a92d7387fc0cb4aabf0cd40d9ec5c908f7d37..dc637bffe63cd2c0e2deb85cb35490c86f134b6d 100644 (file)
@@ -1238,8 +1238,8 @@ static int isc_querycap(struct file *file, void *priv,
 {
        struct isc_device *isc = video_drvdata(file);
 
-       strcpy(cap->driver, ATMEL_ISC_NAME);
-       strcpy(cap->card, "Atmel Image Sensor Controller");
+       strscpy(cap->driver, ATMEL_ISC_NAME, sizeof(cap->driver));
+       strscpy(cap->card, "Atmel Image Sensor Controller", sizeof(cap->card));
        snprintf(cap->bus_info, sizeof(cap->bus_info),
                 "platform:%s", isc->v4l2_dev.name);
 
@@ -1393,7 +1393,7 @@ static int isc_enum_input(struct file *file, void *priv,
 
        inp->type = V4L2_INPUT_TYPE_CAMERA;
        inp->std = 0;
-       strcpy(inp->name, "Camera");
+       strscpy(inp->name, "Camera", sizeof(inp->name));
 
        return 0;
 }
index a96c9337ae581dea353cfc8fc3dcf8d36dca09c6..d6bf96ad474c43180c6aaf209d36c8b23f43e8fa 100644 (file)
@@ -816,10 +816,12 @@ static int vpbe_display_enum_fmt(struct file *file, void  *priv,
        fmt->index = index;
        fmt->type = V4L2_BUF_TYPE_VIDEO_OUTPUT;
        if (index == 0) {
-               strcpy(fmt->description, "YUV 4:2:2 - UYVY");
+               strscpy(fmt->description, "YUV 4:2:2 - UYVY",
+                       sizeof(fmt->description));
                fmt->pixelformat = V4L2_PIX_FMT_UYVY;
        } else {
-               strcpy(fmt->description, "Y/CbCr 4:2:0");
+               strscpy(fmt->description, "Y/CbCr 4:2:0",
+                       sizeof(fmt->description));
                fmt->pixelformat = V4L2_PIX_FMT_NV12;
        }
 
index ddcad7b3e76c21d07609a3938e401052940f853a..ca78eb29641af80ac17392221a7ec448d79e0899 100644 (file)
@@ -616,7 +616,7 @@ struct v4l2_subdev *venc_sub_dev_init(struct v4l2_device *v4l2_dev,
 
        v4l2_subdev_init(&venc->sd, &venc_ops);
 
-       strcpy(venc->sd.name, venc_name);
+       strscpy(venc->sd.name, venc_name, sizeof(venc->sd.name));
        if (v4l2_device_register_subdev(v4l2_dev, &venc->sd) < 0) {
                v4l2_err(v4l2_dev,
                        "vpbe unable to register venc sub device\n");
index f0c2508a6e2e187b938f5688c27242fdfb6a044d..62bced38db104be638d12fe98a3a20576115869f 100644 (file)
@@ -949,11 +949,13 @@ static int vpif_enum_fmt_vid_cap(struct file *file, void  *priv,
        /* Fill in the information about format */
        if (ch->vpifparams.iface.if_type == VPIF_IF_RAW_BAYER) {
                fmt->type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
-               strcpy(fmt->description, "Raw Mode -Bayer Pattern GrRBGb");
+               strscpy(fmt->description, "Raw Mode -Bayer Pattern GrRBGb",
+                       sizeof(fmt->description));
                fmt->pixelformat = V4L2_PIX_FMT_SBGGR8;
        } else {
                fmt->type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
-               strcpy(fmt->description, "YCbCr4:2:2 Semi-Planar");
+               strscpy(fmt->description, "YCbCr4:2:2 Semi-Planar",
+                       sizeof(fmt->description));
                fmt->pixelformat = V4L2_PIX_FMT_NV16;
        }
        return 0;
index fec4341eb93e8efa0f91bcde1f102b34305cbeac..78eba66f4b2bb959a447d153b7a1460a8dde05c0 100644 (file)
@@ -602,7 +602,8 @@ static int vpif_enum_fmt_vid_out(struct file *file, void  *priv,
 
        /* Fill in the information about format */
        fmt->type = V4L2_BUF_TYPE_VIDEO_OUTPUT;
-       strcpy(fmt->description, "YCbCr4:2:2 YC Planar");
+       strscpy(fmt->description, "YCbCr4:2:2 YC Planar",
+               sizeof(fmt->description));
        fmt->pixelformat = V4L2_PIX_FMT_YUV422P;
        fmt->flags = 0;
        return 0;
index 0273302aa7412f7c83a5b1cfe30ae3cd6050614e..ca6d0317ab4246a72a97a06a0653ce34340104a6 100644 (file)
@@ -565,9 +565,9 @@ static const struct videobuf_queue_ops viu_video_qops = {
 static int vidioc_querycap(struct file *file, void *priv,
                           struct v4l2_capability *cap)
 {
-       strcpy(cap->driver, "viu");
-       strcpy(cap->card, "viu");
-       strcpy(cap->bus_info, "platform:viu");
+       strscpy(cap->driver, "viu", sizeof(cap->driver));
+       strscpy(cap->card, "viu", sizeof(cap->card));
+       strscpy(cap->bus_info, "platform:viu", sizeof(cap->bus_info));
        cap->device_caps =      V4L2_CAP_VIDEO_CAPTURE |
                                V4L2_CAP_STREAMING     |
                                V4L2_CAP_VIDEO_OVERLAY |
@@ -941,7 +941,7 @@ static int vidioc_enum_input(struct file *file, void *priv,
 
        inp->type = V4L2_INPUT_TYPE_CAMERA;
        inp->std = fh->dev->vdev->tvnorms;
-       strcpy(inp->name, "Camera");
+       strscpy(inp->name, "Camera", sizeof(inp->name));
        return 0;
 }
 
index 57d2c483ad0973f16db640ffd55e6702b8b4b971..2986cb4b88d0379cac9c5fd401cfa5561dfbe538 100644 (file)
@@ -341,7 +341,7 @@ static int cafe_smbus_setup(struct cafe_camera *cam)
                return -ENOMEM;
        adap->owner = THIS_MODULE;
        adap->algo = &cafe_smbus_algo;
-       strcpy(adap->name, "cafe_ccic");
+       strscpy(adap->name, "cafe_ccic", sizeof(adap->name));
        adap->dev.parent = &cam->pdev->dev;
        i2c_set_adapdata(adap, cam);
        ret = i2c_add_adapter(adap);
index c47011194710bb8eee1f94aad7715c9d3eb12aa5..f8e1af101817340df4c0ea1501925c54cf0009dd 100644 (file)
@@ -1303,8 +1303,8 @@ static int mcam_vidioc_querycap(struct file *file, void *priv,
 {
        struct mcam_camera *cam = video_drvdata(file);
 
-       strcpy(cap->driver, "marvell_ccic");
-       strcpy(cap->card, "marvell_ccic");
+       strscpy(cap->driver, "marvell_ccic", sizeof(cap->driver));
+       strscpy(cap->card, "marvell_ccic", sizeof(cap->card));
        strscpy(cap->bus_info, cam->bus_info, sizeof(cap->bus_info));
        cap->device_caps = V4L2_CAP_VIDEO_CAPTURE |
                V4L2_CAP_READWRITE | V4L2_CAP_STREAMING;
@@ -1421,7 +1421,7 @@ static int mcam_vidioc_enum_input(struct file *filp, void *priv,
                return -EINVAL;
 
        input->type = V4L2_INPUT_TYPE_CAMERA;
-       strcpy(input->name, "Camera");
+       strscpy(input->name, "Camera", sizeof(input->name));
        return 0;
 }
 
index 1a00b1fa79902199e5dd2f25b166492cb51ceca8..44b6859d7238421db2a81e4d58d91f19c1e4b332 100644 (file)
@@ -312,7 +312,7 @@ static int soc_camera_enum_input(struct file *file, void *priv,
        /* default is camera */
        inp->type = V4L2_INPUT_TYPE_CAMERA;
        inp->std = icd->vdev->tvnorms;
-       strcpy(inp->name, "Camera");
+       strscpy(inp->name, "Camera", sizeof(inp->name));
 
        return 0;
 }
index 554870e48750fdf15483dca82d696cc53d5f2bb7..24d5759501a5603a26b55efa0ca1353f1cc43e8f 100644 (file)
@@ -812,7 +812,7 @@ static int viacam_enum_input(struct file *filp, void *priv,
 
        input->type = V4L2_INPUT_TYPE_CAMERA;
        input->std = V4L2_STD_ALL; /* Not sure what should go here */
-       strcpy(input->name, "Camera");
+       strscpy(input->name, "Camera", sizeof(input->name));
        return 0;
 }
 
@@ -990,8 +990,8 @@ out:
 static int viacam_querycap(struct file *filp, void *priv,
                struct v4l2_capability *cap)
 {
-       strcpy(cap->driver, "via-camera");
-       strcpy(cap->card, "via-camera");
+       strscpy(cap->driver, "via-camera", sizeof(cap->driver));
+       strscpy(cap->card, "via-camera", sizeof(cap->card));
        cap->device_caps = V4L2_CAP_VIDEO_CAPTURE |
                V4L2_CAP_READWRITE | V4L2_CAP_STREAMING;
        cap->capabilities = cap->device_caps | V4L2_CAP_DEVICE_CAPS;
index 71105fa4c5f91a8cc2dfe97cc49af21c2152be84..4d822dbed97260f3e97309c7882f5bf77788f125 100644 (file)
@@ -241,11 +241,11 @@ static int vivid_received(struct cec_adapter *adap, struct cec_msg *msg)
                cec_ops_set_osd_string(msg, &disp_ctl, osd);
                switch (disp_ctl) {
                case CEC_OP_DISP_CTL_DEFAULT:
-                       strcpy(dev->osd, osd);
+                       strscpy(dev->osd, osd, sizeof(dev->osd));
                        dev->osd_jiffies = jiffies;
                        break;
                case CEC_OP_DISP_CTL_UNTIL_CLEARED:
-                       strcpy(dev->osd, osd);
+                       strscpy(dev->osd, osd, sizeof(dev->osd));
                        dev->osd_jiffies = 0;
                        break;
                case CEC_OP_DISP_CTL_CLEAR:
index 31db363602e5313e88d253f1fb77b9b06652efd9..06961e7d8036aa3be6b8919bb90db0ddf5029222 100644 (file)
@@ -197,8 +197,8 @@ static int vidioc_querycap(struct file *file, void  *priv,
 {
        struct vivid_dev *dev = video_drvdata(file);
 
-       strcpy(cap->driver, "vivid");
-       strcpy(cap->card, "vivid");
+       strscpy(cap->driver, "vivid", sizeof(cap->driver));
+       strscpy(cap->card, "vivid", sizeof(cap->card));
        snprintf(cap->bus_info, sizeof(cap->bus_info),
                        "platform:%s", dev->v4l2_dev.name);
 
index a6f207b448bee1d29f9701fa95d3912ae551b586..c9d51a5f28389b21b6a7d3d8503d000612ce9cf6 100644 (file)
@@ -191,7 +191,7 @@ static int vidioc_g_tuner(struct file *file, void *priv,
                return -EINVAL;
 
        dsbr100_getstat(radio);
-       strcpy(v->name, "FM");
+       strscpy(v->name, "FM", sizeof(v->name));
        v->type = V4L2_TUNER_RADIO;
        v->rangelow = FREQ_MIN * FREQ_MUL;
        v->rangehigh = FREQ_MAX * FREQ_MUL;
index 0a59d97d4627c54540abed48e337c6b733e79a1d..5cb153727841b72e42f0bcc8c8e563b95b6e8bba 100644 (file)
@@ -222,7 +222,7 @@ static int vidioc_g_tuner(struct file *file, void *priv,
         * retval = ma901radio_get_stat(radio, &is_stereo, &v->signal);
         */
 
-       strcpy(v->name, "FM");
+       strscpy(v->name, "FM", sizeof(v->name));
        v->type = V4L2_TUNER_RADIO;
        v->rangelow = FREQ_MIN * FREQ_MUL;
        v->rangehigh = FREQ_MAX * FREQ_MUL;
index e7c35b184e21dd828df37d2a55a0baaf77c35ab6..ab1324f681995663440e5e8453819175ef118064 100644 (file)
@@ -291,7 +291,7 @@ static int vidioc_g_tuner(struct file *file, void *priv,
        if (retval)
                return retval;
 
-       strcpy(v->name, "FM");
+       strscpy(v->name, "FM", sizeof(v->name));
        v->type = V4L2_TUNER_RADIO;
        v->rangelow = FREQ_MIN * FREQ_MUL;
        v->rangehigh = FREQ_MAX * FREQ_MUL;
index c40e1753f34be9d1158ce215bc0aeca9f39618b1..1d7ab5462c77e47827d1df031c9e2d297c1c47cb 100644 (file)
@@ -622,7 +622,7 @@ static int si470x_vidioc_g_tuner(struct file *file, void *priv,
        }
 
        /* driver constants */
-       strcpy(tuner->name, "FM");
+       strscpy(tuner->name, "FM", sizeof(tuner->name));
        tuner->type = V4L2_TUNER_RADIO;
        tuner->capability = V4L2_TUNER_CAP_LOW | V4L2_TUNER_CAP_STEREO |
                            V4L2_TUNER_CAP_RDS | V4L2_TUNER_CAP_RDS_BLOCK_IO |
index c5f433b2471392117b21e2c32f1135426a4a548e..e25fd4d4d280c7c8f2efabf5bde33a5eb039bcc8 100644 (file)
@@ -249,7 +249,7 @@ static int fm_v4l2_vidioc_g_audio(struct file *file, void *priv,
                struct v4l2_audio *audio)
 {
        memset(audio, 0, sizeof(*audio));
-       strcpy(audio->name, "Radio");
+       strscpy(audio->name, "Radio", sizeof(audio->name));
        audio->capability = V4L2_AUDCAP_STEREO;
 
        return 0;
@@ -293,7 +293,7 @@ static int fm_v4l2_vidioc_g_tuner(struct file *file, void *priv,
        if (ret != 0)
                return ret;
 
-       strcpy(tuner->name, "FM");
+       strscpy(tuner->name, "FM", sizeof(tuner->name));
        tuner->type = V4L2_TUNER_RADIO;
        /* Store rangelow and rangehigh freq in unit of 62.5 Hz */
        tuner->rangelow = bottom_freq * 16;
index aa25c19437adae8154a8808a509181f80d064e99..efbf210147c73a289b443cc938c6d2c32798b436 100644 (file)
@@ -1218,7 +1218,7 @@ static int vidioc_enum_fmt_vid_cap(struct file *file, void  *priv,
        dprintk(1, "%s called\n", __func__);
 
        f->type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
-       strcpy(f->description, "Packed YUV2");
+       strscpy(f->description, "Packed YUV2", sizeof(f->description));
 
        f->flags = 0;
        f->pixelformat = V4L2_PIX_FMT_UYVY;
@@ -1349,7 +1349,7 @@ static int vidioc_enum_input(struct file *file, void *priv,
                return -EINVAL;
 
        input->index = tmp;
-       strcpy(input->name, inames[AUVI_INPUT(tmp).type]);
+       strscpy(input->name, inames[AUVI_INPUT(tmp).type], sizeof(input->name));
        if ((AUVI_INPUT(tmp).type == AU0828_VMUX_TELEVISION) ||
            (AUVI_INPUT(tmp).type == AU0828_VMUX_CABLE)) {
                input->type |= V4L2_INPUT_TYPE_TUNER;
@@ -1465,9 +1465,9 @@ static int vidioc_enumaudio(struct file *file, void *priv, struct v4l2_audio *a)
        dprintk(1, "%s called\n", __func__);
 
        if (a->index == 0)
-               strcpy(a->name, "Television");
+               strscpy(a->name, "Television", sizeof(a->name));
        else
-               strcpy(a->name, "Line in");
+               strscpy(a->name, "Line in", sizeof(a->name));
 
        a->capability = V4L2_AUDCAP_STEREO;
        return 0;
@@ -1482,9 +1482,9 @@ static int vidioc_g_audio(struct file *file, void *priv, struct v4l2_audio *a)
 
        a->index = dev->ctrl_ainput;
        if (a->index == 0)
-               strcpy(a->name, "Television");
+               strscpy(a->name, "Television", sizeof(a->name));
        else
-               strcpy(a->name, "Line in");
+               strscpy(a->name, "Line in", sizeof(a->name));
 
        a->capability = V4L2_AUDCAP_STEREO;
        return 0;
@@ -1518,7 +1518,7 @@ static int vidioc_g_tuner(struct file *file, void *priv, struct v4l2_tuner *t)
        dprintk(1, "%s called std_set %d dev_state %ld\n", __func__,
                dev->std_set_in_tuner_core, dev->dev_state);
 
-       strcpy(t->name, "Auvitek tuner");
+       strscpy(t->name, "Auvitek tuner", sizeof(t->name));
 
        au0828_init_tuner(dev);
        i2c_gate_ctrl(dev, 1);
@@ -1978,7 +1978,7 @@ int au0828_analog_register(struct au0828_dev *dev,
        dev->vdev.lock = &dev->lock;
        dev->vdev.queue = &dev->vb_vidq;
        dev->vdev.queue->lock = &dev->vb_queue_lock;
-       strcpy(dev->vdev.name, "au0828a video");
+       strscpy(dev->vdev.name, "au0828a video", sizeof(dev->vdev.name));
 
        /* Setup the VBI device */
        dev->vbi_dev = au0828_video_template;
@@ -1986,7 +1986,7 @@ int au0828_analog_register(struct au0828_dev *dev,
        dev->vbi_dev.lock = &dev->lock;
        dev->vbi_dev.queue = &dev->vb_vbiq;
        dev->vbi_dev.queue->lock = &dev->vb_vbi_queue_lock;
-       strcpy(dev->vbi_dev.name, "au0828a vbi");
+       strscpy(dev->vbi_dev.name, "au0828a vbi", sizeof(dev->vbi_dev.name));
 
        /* Init entities at the Media Controller */
        au0828_analog_create_entities(dev);
index 99f106b13280f1f6d16685f69b8b8c7d1d316d11..aa7f3c307b224150638e5c2a1e4c7d192744fa81 100644 (file)
@@ -219,12 +219,12 @@ static int cpia2_querycap(struct file *file, void *fh, struct v4l2_capability *v
 {
        struct camera_data *cam = video_drvdata(file);
 
-       strcpy(vc->driver, "cpia2");
+       strscpy(vc->driver, "cpia2", sizeof(vc->driver));
 
        if (cam->params.pnp_id.product == 0x151)
-               strcpy(vc->card, "QX5 Microscope");
+               strscpy(vc->card, "QX5 Microscope", sizeof(vc->card));
        else
-               strcpy(vc->card, "CPiA2 Camera");
+               strscpy(vc->card, "CPiA2 Camera", sizeof(vc->card));
        switch (cam->params.pnp_id.device_type) {
        case DEVICE_STV_672:
                strcat(vc->card, " (672/");
@@ -281,7 +281,7 @@ static int cpia2_enum_input(struct file *file, void *fh, struct v4l2_input *i)
 {
        if (i->index)
                return -EINVAL;
-       strcpy(i->name, "Camera");
+       strscpy(i->name, "Camera", sizeof(i->name));
        i->type = V4L2_INPUT_TYPE_CAMERA;
        return 0;
 }
@@ -319,11 +319,11 @@ static int cpia2_enum_fmt_vid_cap(struct file *file, void *fh,
        f->flags = V4L2_FMT_FLAG_COMPRESSED;
        switch(index) {
        case 0:
-               strcpy(f->description, "MJPEG");
+               strscpy(f->description, "MJPEG", sizeof(f->description));
                f->pixelformat = V4L2_PIX_FMT_MJPEG;
                break;
        case 1:
-               strcpy(f->description, "JPEG");
+               strscpy(f->description, "JPEG", sizeof(f->description));
                f->pixelformat = V4L2_PIX_FMT_JPEG;
                break;
        default:
index 32ee7b3f21c9b5cecc00d5b7fd4445be7d69dea3..77f2c65eb79a9489963bb7dca29b3bf4e5134cb3 100644 (file)
@@ -679,10 +679,10 @@ static int cx231xx_audio_init(struct cx231xx *dev)
                        &snd_cx231xx_pcm_capture);
        pcm->info_flags = 0;
        pcm->private_data = dev;
-       strcpy(pcm->name, "Conexant cx231xx Capture");
-       strcpy(card->driver, "Cx231xx-Audio");
-       strcpy(card->shortname, "Cx231xx Audio");
-       strcpy(card->longname, "Conexant cx231xx Audio");
+       strscpy(pcm->name, "Conexant cx231xx Capture", sizeof(pcm->name));
+       strscpy(card->driver, "Cx231xx-Audio", sizeof(card->driver));
+       strscpy(card->shortname, "Cx231xx Audio", sizeof(card->shortname));
+       strscpy(card->longname, "Conexant cx231xx Audio", sizeof(card->longname));
 
        INIT_WORK(&dev->wq_trigger, audio_trigger);
 
index 7759bc66f18c675bf1aed201b1472abfd83f6c63..29160df76cf763282a99f765dc5f700380a69fef 100644 (file)
@@ -1169,7 +1169,7 @@ int cx231xx_enum_input(struct file *file, void *priv,
        i->index = n;
        i->type = V4L2_INPUT_TYPE_CAMERA;
 
-       strcpy(i->name, iname[INPUT(n)->type]);
+       strscpy(i->name, iname[INPUT(n)->type], sizeof(i->name));
 
        if ((CX231XX_VMUX_TELEVISION == INPUT(n)->type) ||
            (CX231XX_VMUX_CABLE == INPUT(n)->type))
@@ -1244,7 +1244,7 @@ int cx231xx_g_tuner(struct file *file, void *priv, struct v4l2_tuner *t)
        if (0 != t->index)
                return -EINVAL;
 
-       strcpy(t->name, "Tuner");
+       strscpy(t->name, "Tuner", sizeof(t->name));
 
        t->type = V4L2_TUNER_ANALOG_TV;
        t->capability = V4L2_TUNER_CAP_NORM;
@@ -1716,7 +1716,7 @@ static int radio_g_tuner(struct file *file, void *priv, struct v4l2_tuner *t)
        if (t->index)
                return -EINVAL;
 
-       strcpy(t->name, "Radio");
+       strscpy(t->name, "Radio", sizeof(t->name));
 
        call_all(dev, tuner, g_tuner, t);
 
@@ -2242,7 +2242,8 @@ int cx231xx_register_analog_devices(struct cx231xx *dev)
 
        /* Initialize VBI template */
        cx231xx_vbi_template = cx231xx_video_template;
-       strcpy(cx231xx_vbi_template.name, "cx231xx-vbi");
+       strscpy(cx231xx_vbi_template.name, "cx231xx-vbi",
+               sizeof(cx231xx_vbi_template.name));
 
        /* Allocate and fill vbi video_device struct */
        cx231xx_vdev_init(dev, &dev->vbi_dev, &cx231xx_vbi_template, "vbi");
index 8e799ae1df69282e7ce3db05f64f70d4bf7774aa..d5e2c19f600d7e2456dd8a8e30907f06453b271b 100644 (file)
@@ -938,11 +938,11 @@ static int em28xx_audio_init(struct em28xx *dev)
        snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &snd_em28xx_pcm_capture);
        pcm->info_flags = 0;
        pcm->private_data = dev;
-       strcpy(pcm->name, "Empia 28xx Capture");
+       strscpy(pcm->name, "Empia 28xx Capture", sizeof(pcm->name));
 
-       strcpy(card->driver, "Em28xx-Audio");
-       strcpy(card->shortname, "Em28xx Audio");
-       strcpy(card->longname, "Empia Em28xx Audio");
+       strscpy(card->driver, "Em28xx-Audio", sizeof(card->driver));
+       strscpy(card->shortname, "Em28xx Audio", sizeof(card->shortname));
+       strscpy(card->longname, "Empia Em28xx Audio", sizeof(card->longname));
 
        INIT_WORK(&adev->wq_trigger, audio_trigger);
 
index e19d6342e0d0af74311dc7943c0a56969b80d1ac..02c13d71e6c1a17b1a66c856d948f7de34e0068a 100644 (file)
@@ -985,7 +985,8 @@ int em28xx_i2c_register(struct em28xx *dev, unsigned int bus,
 
        dev->i2c_adap[bus] = em28xx_adap_template;
        dev->i2c_adap[bus].dev.parent = &dev->intf->dev;
-       strcpy(dev->i2c_adap[bus].name, dev_name(&dev->intf->dev));
+       strscpy(dev->i2c_adap[bus].name, dev_name(&dev->intf->dev),
+               sizeof(dev->i2c_adap[bus].name));
 
        dev->i2c_bus[bus].bus = bus;
        dev->i2c_bus[bus].algo_type = algo_type;
index 5e8a26fa719a69493e7eabba49b2d18a67213f2c..917602954bfbd99cf21f82a977557520a083ae17 100644 (file)
@@ -1675,7 +1675,7 @@ static int vidioc_enum_input(struct file *file, void *priv,
 
        i->type = V4L2_INPUT_TYPE_CAMERA;
 
-       strcpy(i->name, iname[INPUT(n)->type]);
+       strscpy(i->name, iname[INPUT(n)->type], sizeof(i->name));
 
        if (INPUT(n)->type == EM28XX_VMUX_TELEVISION)
                i->type = V4L2_INPUT_TYPE_TUNER;
@@ -1716,28 +1716,28 @@ static int vidioc_g_audio(struct file *file, void *priv, struct v4l2_audio *a)
 
        switch (a->index) {
        case EM28XX_AMUX_VIDEO:
-               strcpy(a->name, "Television");
+               strscpy(a->name, "Television", sizeof(a->name));
                break;
        case EM28XX_AMUX_LINE_IN:
-               strcpy(a->name, "Line In");
+               strscpy(a->name, "Line In", sizeof(a->name));
                break;
        case EM28XX_AMUX_VIDEO2:
-               strcpy(a->name, "Television alt");
+               strscpy(a->name, "Television alt", sizeof(a->name));
                break;
        case EM28XX_AMUX_PHONE:
-               strcpy(a->name, "Phone");
+               strscpy(a->name, "Phone", sizeof(a->name));
                break;
        case EM28XX_AMUX_MIC:
-               strcpy(a->name, "Mic");
+               strscpy(a->name, "Mic", sizeof(a->name));
                break;
        case EM28XX_AMUX_CD:
-               strcpy(a->name, "CD");
+               strscpy(a->name, "CD", sizeof(a->name));
                break;
        case EM28XX_AMUX_AUX:
-               strcpy(a->name, "Aux");
+               strscpy(a->name, "Aux", sizeof(a->name));
                break;
        case EM28XX_AMUX_PCM_OUT:
-               strcpy(a->name, "PCM");
+               strscpy(a->name, "PCM", sizeof(a->name));
                break;
        default:
                return -EINVAL;
@@ -1776,7 +1776,7 @@ static int vidioc_g_tuner(struct file *file, void *priv,
        if (t->index != 0)
                return -EINVAL;
 
-       strcpy(t->name, "Tuner");
+       strscpy(t->name, "Tuner", sizeof(t->name));
 
        v4l2_device_call_all(&dev->v4l2->v4l2_dev, 0, tuner, g_tuner, t);
        return 0;
@@ -2045,7 +2045,7 @@ static int radio_g_tuner(struct file *file, void *priv,
        if (unlikely(t->index > 0))
                return -EINVAL;
 
-       strcpy(t->name, "Radio");
+       strscpy(t->name, "Radio", sizeof(t->name));
 
        v4l2_device_call_all(&dev->v4l2->v4l2_dev, 0, tuner, g_tuner, t);
 
index 9ab071f8993daf6cff286541d5b3b720fcf1c368..e082086428a43a23c25c6a2b2dcf9a566903c612 100644 (file)
@@ -578,8 +578,8 @@ static int vidioc_querycap(struct file *file, void  *priv,
 {
        struct hdpvr_device *dev = video_drvdata(file);
 
-       strcpy(cap->driver, "hdpvr");
-       strcpy(cap->card, "Hauppauge HD PVR");
+       strscpy(cap->driver, "hdpvr", sizeof(cap->driver));
+       strscpy(cap->card, "Hauppauge HD PVR", sizeof(cap->card));
        usb_make_path(dev->udev, cap->bus_info, sizeof(cap->bus_info));
        cap->device_caps = V4L2_CAP_VIDEO_CAPTURE | V4L2_CAP_AUDIO |
                            V4L2_CAP_READWRITE;
@@ -1238,7 +1238,8 @@ int hdpvr_register_videodev(struct hdpvr_device *dev, struct device *parent,
 
        /* setup and register video device */
        dev->video_dev = hdpvr_video_template;
-       strcpy(dev->video_dev.name, "Hauppauge HD PVR");
+       strscpy(dev->video_dev.name, "Hauppauge HD PVR",
+               sizeof(dev->video_dev.name));
        dev->video_dev.v4l2_dev = &dev->v4l2_dev;
        video_set_drvdata(&dev->video_dev, dev);
 
index 350635826aaed39898519ba4844327ab9d4695eb..365c78b748dd5cb1e5b739a462a7e4df656738b7 100644 (file)
@@ -571,7 +571,8 @@ static int pulse8_cec_adap_log_addr(struct cec_adapter *adap, u8 log_addr)
                        memset(osd_str + osd_len, ' ', 4 - osd_len);
                        osd_len = 4;
                        osd_str[osd_len] = '\0';
-                       strcpy(adap->log_addrs.osd_name, osd_str);
+                       strscpy(adap->log_addrs.osd_name, osd_str,
+                               sizeof(adap->log_addrs.osd_name));
                }
                err = pulse8_send_and_wait(pulse8, cmd, 1 + osd_len,
                                           MSGCODE_COMMAND_ACCEPTED, 0);
index 54b036d39c5b973eaec5c8be428050023109fdb9..72704f4d5330b9bbb0cb9d602dd1d59e6981dd85 100644 (file)
@@ -1027,7 +1027,7 @@ static int usb_pwc_probe(struct usb_interface *intf, const struct usb_device_id
 
        /* Init video_device structure */
        pdev->vdev = pwc_template;
-       strcpy(pdev->vdev.name, name);
+       strscpy(pdev->vdev.name, name, sizeof(pdev->vdev.name));
        pdev->vdev.queue = &pdev->vb_queue;
        pdev->vdev.queue->lock = &pdev->vb_queue_lock;
        video_set_drvdata(&pdev->vdev, pdev);
index 0673238c2c63e7fcf413d91887d8e6f0abca34c8..bef6e4ef8a7e14812f064d566e37e9af497fc14c 100644 (file)
@@ -492,7 +492,7 @@ static int pwc_querycap(struct file *file, void *fh, struct v4l2_capability *cap
 {
        struct pwc_device *pdev = video_drvdata(file);
 
-       strcpy(cap->driver, PWC_NAME);
+       strscpy(cap->driver, PWC_NAME, sizeof(cap->driver));
        strscpy(cap->card, pdev->vdev.name, sizeof(cap->card));
        usb_make_path(pdev->udev, cap->bus_info, sizeof(cap->bus_info));
        cap->device_caps = V4L2_CAP_VIDEO_CAPTURE | V4L2_CAP_STREAMING |
index cecdcbcd400c5f6c1a6c1f841d7582b9bf0f83b4..d9964da05976b5bc925fd12626137d0e08162782 100644 (file)
@@ -141,7 +141,8 @@ static void rain_irq_work_handler(struct work_struct *work)
                            !memcmp(rain->cmd, "STA", 3)) {
                                rain_process_msg(rain);
                        } else {
-                               strcpy(rain->cmd_reply, rain->cmd);
+                               strscpy(rain->cmd_reply, rain->cmd,
+                                       sizeof(rain->cmd_reply));
                                complete(&rain->cmd_done);
                        }
                        rain->cmd_idx = 0;
index 62a12d5356ad2a4e8052a4997ec059f17005a10f..c3a15564e5cb58aaf7639ba444fea54a84d24dfe 100644 (file)
@@ -260,7 +260,7 @@ int stk1160_i2c_register(struct stk1160 *dev)
 
        dev->i2c_adap = adap_template;
        dev->i2c_adap.dev.parent = dev->dev;
-       strcpy(dev->i2c_adap.name, "stk1160");
+       strscpy(dev->i2c_adap.name, "stk1160", sizeof(dev->i2c_adap.name));
        dev->i2c_adap.algo_data = dev;
 
        i2c_set_adapdata(&dev->i2c_adap, &dev->v4l2_dev);
index bbf191b71f384e4e649fe3b1177978d41dfb45c2..701ed3d4afe64a493dc225198dff2164bd365a3f 100644 (file)
@@ -344,8 +344,8 @@ static int vidioc_querycap(struct file *file,
 {
        struct stk1160 *dev = video_drvdata(file);
 
-       strcpy(cap->driver, "stk1160");
-       strcpy(cap->card, "stk1160");
+       strscpy(cap->driver, "stk1160", sizeof(cap->driver));
+       strscpy(cap->card, "stk1160", sizeof(cap->card));
        usb_make_path(dev->udev, cap->bus_info, sizeof(cap->bus_info));
        cap->device_caps =
                V4L2_CAP_VIDEO_CAPTURE |
index 5accb52410720196b24181e18ee0620e68dbc223..e11d5d5b7c263e9a00be1e2334b108f2f14111ee 100644 (file)
@@ -793,8 +793,8 @@ static int stk_vidioc_querycap(struct file *filp,
 {
        struct stk_camera *dev = video_drvdata(filp);
 
-       strcpy(cap->driver, "stk");
-       strcpy(cap->card, "stk");
+       strscpy(cap->driver, "stk", sizeof(cap->driver));
+       strscpy(cap->card, "stk", sizeof(cap->card));
        usb_make_path(dev->udev, cap->bus_info, sizeof(cap->bus_info));
 
        cap->device_caps = V4L2_CAP_VIDEO_CAPTURE
@@ -809,7 +809,7 @@ static int stk_vidioc_enum_input(struct file *filp,
        if (input->index != 0)
                return -EINVAL;
 
-       strcpy(input->name, "Syntek USB Camera");
+       strscpy(input->name, "Syntek USB Camera", sizeof(input->name));
        input->type = V4L2_INPUT_TYPE_CAMERA;
        return 0;
 }
@@ -859,23 +859,23 @@ static int stk_vidioc_enum_fmt_vid_cap(struct file *filp,
        switch (fmtd->index) {
        case 0:
                fmtd->pixelformat = V4L2_PIX_FMT_RGB565;
-               strcpy(fmtd->description, "r5g6b5");
+               strscpy(fmtd->description, "r5g6b5", sizeof(fmtd->description));
                break;
        case 1:
                fmtd->pixelformat = V4L2_PIX_FMT_RGB565X;
-               strcpy(fmtd->description, "r5g6b5BE");
+               strscpy(fmtd->description, "r5g6b5BE", sizeof(fmtd->description));
                break;
        case 2:
                fmtd->pixelformat = V4L2_PIX_FMT_UYVY;
-               strcpy(fmtd->description, "yuv4:2:2");
+               strscpy(fmtd->description, "yuv4:2:2", sizeof(fmtd->description));
                break;
        case 3:
                fmtd->pixelformat = V4L2_PIX_FMT_SBGGR8;
-               strcpy(fmtd->description, "Raw bayer");
+               strscpy(fmtd->description, "Raw bayer", sizeof(fmtd->description));
                break;
        case 4:
                fmtd->pixelformat = V4L2_PIX_FMT_YUYV;
-               strcpy(fmtd->description, "yuv4:2:2");
+               strscpy(fmtd->description, "yuv4:2:2", sizeof(fmtd->description));
                break;
        default:
                return -EINVAL;
index f18cffae4c85a15bbaf38a170de44fa0e6c637a3..b965931793b57acf7edd67d67a68e0e71fa99035 100644 (file)
@@ -429,8 +429,8 @@ static int tm6000_audio_init(struct tm6000_core *dev)
                snd_printk(KERN_ERR "cannot create card instance %d\n", devnr);
                return rc;
        }
-       strcpy(card->driver, "tm6000-alsa");
-       strcpy(card->shortname, "TM5600/60x0");
+       strscpy(card->driver, "tm6000-alsa", sizeof(card->driver));
+       strscpy(card->shortname, "TM5600/60x0", sizeof(card->shortname));
        sprintf(card->longname, "TM5600/60x0 Audio at bus %d device %d",
                dev->udev->bus->busnum, dev->udev->devnum);
 
@@ -456,7 +456,7 @@ static int tm6000_audio_init(struct tm6000_core *dev)
 
        pcm->info_flags = 0;
        pcm->private_data = chip;
-       strcpy(pcm->name, "Trident TM5600/60x0");
+       strscpy(pcm->name, "Trident TM5600/60x0", sizeof(pcm->name));
 
        snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &snd_tm6000_pcm_ops);
 
index f3082bd44ce6aedfdf9a9227ef4adb5fc428f0f1..49d7eb0c4cbfe31e154381fe66354e208cefb64c 100644 (file)
@@ -1091,7 +1091,7 @@ static int vidioc_enum_input(struct file *file, void *priv,
        else
                i->type = V4L2_INPUT_TYPE_CAMERA;
 
-       strcpy(i->name, iname[dev->vinput[n].type]);
+       strscpy(i->name, iname[dev->vinput[n].type], sizeof(i->name));
 
        i->std = TM6000_STD;
 
@@ -1188,7 +1188,7 @@ static int vidioc_g_tuner(struct file *file, void *priv,
        if (0 != t->index)
                return -EINVAL;
 
-       strcpy(t->name, "Television");
+       strscpy(t->name, "Television", sizeof(t->name));
        t->type       = V4L2_TUNER_ANALOG_TV;
        t->capability = V4L2_TUNER_CAP_NORM | V4L2_TUNER_CAP_STEREO;
        t->rangehigh  = 0xffffffffUL;
@@ -1268,7 +1268,7 @@ static int radio_g_tuner(struct file *file, void *priv,
                return -EINVAL;
 
        memset(t, 0, sizeof(*t));
-       strcpy(t->name, "Radio");
+       strscpy(t->name, "Radio", sizeof(t->name));
        t->type = V4L2_TUNER_RADIO;
        t->capability = V4L2_TUNER_CAP_LOW | V4L2_TUNER_CAP_STEREO;
        t->rxsubchans = V4L2_TUNER_SUB_STEREO;
index eed56895c2b99052295614f742441f94d923a836..6eb84cf007b4ca62f640324b226619810205cb48 100644 (file)
@@ -1686,7 +1686,7 @@ static int ttusb_probe(struct usb_interface *intf, const struct usb_device_id *i
 
        /* i2c */
        memset(&ttusb->i2c_adap, 0, sizeof(struct i2c_adapter));
-       strcpy(ttusb->i2c_adap.name, "TTUSB DEC");
+       strscpy(ttusb->i2c_adap.name, "TTUSB DEC", sizeof(ttusb->i2c_adap.name));
 
        i2c_set_adapdata(&ttusb->i2c_adap, ttusb);
 
index f4e758e5f3ec8887bc0d3b6198ff41c8fac14e4a..dd2ff8ed6c6a2b34949e99105853d251cf38295c 100644 (file)
@@ -504,9 +504,9 @@ static int vidioc_enum_input(struct file *file, void *priv,
        switch (chan) {
        case 0:
                if (usbvision_device_data[usbvision->dev_model].video_channels == 4) {
-                       strcpy(vi->name, "White Video Input");
+                       strscpy(vi->name, "White Video Input", sizeof(vi->name));
                } else {
-                       strcpy(vi->name, "Television");
+                       strscpy(vi->name, "Television", sizeof(vi->name));
                        vi->type = V4L2_INPUT_TYPE_TUNER;
                        vi->tuner = chan;
                        vi->std = USBVISION_NORMS;
@@ -515,22 +515,23 @@ static int vidioc_enum_input(struct file *file, void *priv,
        case 1:
                vi->type = V4L2_INPUT_TYPE_CAMERA;
                if (usbvision_device_data[usbvision->dev_model].video_channels == 4)
-                       strcpy(vi->name, "Green Video Input");
+                       strscpy(vi->name, "Green Video Input", sizeof(vi->name));
                else
-                       strcpy(vi->name, "Composite Video Input");
+                       strscpy(vi->name, "Composite Video Input",
+                               sizeof(vi->name));
                vi->std = USBVISION_NORMS;
                break;
        case 2:
                vi->type = V4L2_INPUT_TYPE_CAMERA;
                if (usbvision_device_data[usbvision->dev_model].video_channels == 4)
-                       strcpy(vi->name, "Yellow Video Input");
+                       strscpy(vi->name, "Yellow Video Input", sizeof(vi->name));
                else
-                       strcpy(vi->name, "S-Video Input");
+                       strscpy(vi->name, "S-Video Input", sizeof(vi->name));
                vi->std = USBVISION_NORMS;
                break;
        case 3:
                vi->type = V4L2_INPUT_TYPE_CAMERA;
-               strcpy(vi->name, "Red Video Input");
+               strscpy(vi->name, "Red Video Input", sizeof(vi->name));
                vi->std = USBVISION_NORMS;
                break;
        }
@@ -589,9 +590,9 @@ static int vidioc_g_tuner(struct file *file, void *priv,
        if (vt->index)  /* Only tuner 0 */
                return -EINVAL;
        if (vt->type == V4L2_TUNER_RADIO)
-               strcpy(vt->name, "Radio");
+               strscpy(vt->name, "Radio", sizeof(vt->name));
        else
-               strcpy(vt->name, "Television");
+               strscpy(vt->name, "Television", sizeof(vt->name));
 
        /* Let clients fill in the remainder of this struct */
        call_all(usbvision, tuner, g_tuner, vt);
@@ -814,7 +815,8 @@ static int vidioc_enum_fmt_vid_cap(struct file *file, void  *priv,
 {
        if (vfd->index >= USBVISION_SUPPORTED_PALETTES - 1)
                return -EINVAL;
-       strcpy(vfd->description, usbvision_v4l2_format[vfd->index].desc);
+       strscpy(vfd->description, usbvision_v4l2_format[vfd->index].desc,
+               sizeof(vfd->description));
        vfd->pixelformat = usbvision_v4l2_format[vfd->index].format;
        return 0;
 }
index 3aa809af5ea7d136ad193c66bc39ce6fd704b352..bc369a0934a36258d99b5d6dde0b02dc51fe6d8b 100644 (file)
@@ -2132,7 +2132,7 @@ static int uvc_probe(struct usb_interface *intf,
        if (udev->serial)
                strscpy(dev->mdev.serial, udev->serial,
                        sizeof(dev->mdev.serial));
-       strcpy(dev->mdev.bus_info, udev->devpath);
+       strscpy(dev->mdev.bus_info, udev->devpath, sizeof(dev->mdev.bus_info));
        dev->mdev.hw_revision = le16_to_cpu(udev->descriptor.bcdDevice);
        media_device_init(&dev->mdev);
 
index 0ba98583c7360b6342ee1739ae8927c667897a6a..ab35554cbffab3cc63d9a5ad74be721fb510944c 100644 (file)
@@ -719,7 +719,7 @@ static int zr364xx_vidioc_enum_input(struct file *file, void *priv,
 {
        if (i->index != 0)
                return -EINVAL;
-       strcpy(i->name, DRIVER_DESC " Camera");
+       strscpy(i->name, DRIVER_DESC " Camera", sizeof(i->name));
        i->type = V4L2_INPUT_TYPE_CAMERA;
        return 0;
 }
@@ -765,7 +765,7 @@ static int zr364xx_vidioc_enum_fmt_vid_cap(struct file *file,
        if (f->index > 0)
                return -EINVAL;
        f->flags = V4L2_FMT_FLAG_COMPRESSED;
-       strcpy(f->description, formats[0].name);
+       strscpy(f->description, formats[0].name, sizeof(f->description));
        f->pixelformat = formats[0].fourcc;
        return 0;
 }
index e55c815b9b656e7837ce2ae6da4a93c4017b94c1..bdf6ee5ad96cf51a9e1ab993a2ee6f7031e70c48 100644 (file)
@@ -639,7 +639,8 @@ static int vpfe_probe(struct platform_device *pdev)
                goto probe_disable_clock;
 
        vpfe_dev->media_dev.dev = vpfe_dev->pdev;
-       strcpy((char *)&vpfe_dev->media_dev.model, "davinci-media");
+       strscpy((char *)&vpfe_dev->media_dev.model, "davinci-media",
+               sizeof(vpfe_dev->media_dev.model));
 
        ret = media_device_register(&vpfe_dev->media_dev);
        if (ret) {
index ceeeb3069a0248d361753050fd595e889c25c58d..7b457a4b7df563d71d825ec7b060ddf002dff306 100644 (file)
@@ -597,7 +597,7 @@ static int csi2_probe(struct platform_device *pdev)
        csi2->sd.dev = &pdev->dev;
        csi2->sd.owner = THIS_MODULE;
        csi2->sd.flags = V4L2_SUBDEV_FL_HAS_DEVNODE;
-       strcpy(csi2->sd.name, DEVICE_NAME);
+       strscpy(csi2->sd.name, DEVICE_NAME, sizeof(csi2->sd.name));
        csi2->sd.entity.function = MEDIA_ENT_F_VID_IF_BRIDGE;
        csi2->sd.grp_id = IMX_MEDIA_GRP_ID_CSI2;
 
index e69a43ae74c2e17e3b93a3ebe73954daaefd3593..94dadbba7cd5f960922ec9d19c3ba828adf5eeda 100644 (file)
@@ -1048,7 +1048,7 @@ static int zr36057_init (struct zoran *zr)
        *zr->video_dev = zoran_template;
        zr->video_dev->v4l2_dev = &zr->v4l2_dev;
        zr->video_dev->lock = &zr->lock;
-       strcpy(zr->video_dev->name, ZR_DEVNAME(zr));
+       strscpy(zr->video_dev->name, ZR_DEVNAME(zr), sizeof(zr->video_dev->name));
        /* It's not a mem2mem device, but you can both capture and output from
           one and the same device. This should really be split up into two
           device nodes, but that's a job for another day. */