aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/video/gspca/gspca.c
diff options
context:
space:
mode:
authorHans de Goede <hdegoede@redhat.com>2010-12-31 03:05:56 -0500
committerMauro Carvalho Chehab <mchehab@redhat.com>2011-01-19 08:44:58 -0500
commitee3629914b2b115f00f4197e80b1e7cb12881059 (patch)
treee3234e9d6c17dceec91e604782adb0e796364b1a /drivers/media/video/gspca/gspca.c
parentd642de2ed472df308f8ee49417e29030f69b2095 (diff)
[media] gspca_main: Simplify read mode memory type checks
gspca_dev->memory == GSPCA_MEMORY_NO implies gspca_dev->nframes == 0, so there is no need to check for both in dev_poll. The check in dev_read also is more complex then needed, as dqbuf which dev_read calls already does all necessary checks. Moreover dqbuf is holding the proper locks while checking where as dev_read itself is not. Signed-off-by: Hans de Goede <hdegoede@redhat.com> Acked-by: Jean-Francois Moine <moinejf@free.fr> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/media/video/gspca/gspca.c')
-rw-r--r--drivers/media/video/gspca/gspca.c14
1 files changed, 2 insertions, 12 deletions
diff --git a/drivers/media/video/gspca/gspca.c b/drivers/media/video/gspca/gspca.c
index adab34f91a68..244fb76eaead 100644
--- a/drivers/media/video/gspca/gspca.c
+++ b/drivers/media/video/gspca/gspca.c
@@ -2019,9 +2019,7 @@ static unsigned int dev_poll(struct file *file, poll_table *wait)
2019 poll_wait(file, &gspca_dev->wq, wait); 2019 poll_wait(file, &gspca_dev->wq, wait);
2020 2020
2021 /* if reqbufs is not done, the user would use read() */ 2021 /* if reqbufs is not done, the user would use read() */
2022 if (gspca_dev->nframes == 0) { 2022 if (gspca_dev->memory == GSPCA_MEMORY_NO) {
2023 if (gspca_dev->memory != GSPCA_MEMORY_NO)
2024 return POLLERR; /* not the 1st time */
2025 ret = read_alloc(gspca_dev, file); 2023 ret = read_alloc(gspca_dev, file);
2026 if (ret != 0) 2024 if (ret != 0)
2027 return POLLERR; 2025 return POLLERR;
@@ -2053,18 +2051,10 @@ static ssize_t dev_read(struct file *file, char __user *data,
2053 PDEBUG(D_FRAM, "read (%zd)", count); 2051 PDEBUG(D_FRAM, "read (%zd)", count);
2054 if (!gspca_dev->present) 2052 if (!gspca_dev->present)
2055 return -ENODEV; 2053 return -ENODEV;
2056 switch (gspca_dev->memory) { 2054 if (gspca_dev->memory == GSPCA_MEMORY_NO) { /* first time ? */
2057 case GSPCA_MEMORY_NO: /* first time */
2058 ret = read_alloc(gspca_dev, file); 2055 ret = read_alloc(gspca_dev, file);
2059 if (ret != 0) 2056 if (ret != 0)
2060 return ret; 2057 return ret;
2061 break;
2062 case GSPCA_MEMORY_READ:
2063 if (gspca_dev->capt_file == file)
2064 break;
2065 /* fall thru */
2066 default:
2067 return -EINVAL;
2068 } 2058 }
2069 2059
2070 /* get a frame */ 2060 /* get a frame */