aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media
diff options
context:
space:
mode:
authorSteven Toth <stoth@linuxtv.org>2008-09-25 23:16:25 -0400
committerMauro Carvalho Chehab <mchehab@redhat.com>2008-10-12 07:37:11 -0400
commitd48cb402a1ba48c4ad4a36c3c561386027318459 (patch)
treeef41126f8718540d976e27819b39a1e31acf9a58 /drivers/media
parent459702bf98ae2bd20bad1e271c615aca4972c609 (diff)
V4L/DVB (9071): S2API: Implement result codes for individual commands
This allows application developers to determine which particular command in a sequence is invalid, or failing with error. Signed-off-by: Steven Toth <stoth@linuxtv.org> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/media')
-rw-r--r--drivers/media/dvb/dvb-core/dvb_frontend.c12
1 files changed, 8 insertions, 4 deletions
diff --git a/drivers/media/dvb/dvb-core/dvb_frontend.c b/drivers/media/dvb/dvb-core/dvb_frontend.c
index 7da25372078..0ef9c2a2af8 100644
--- a/drivers/media/dvb/dvb-core/dvb_frontend.c
+++ b/drivers/media/dvb/dvb-core/dvb_frontend.c
@@ -1262,8 +1262,10 @@ static int dvb_frontend_ioctl_properties(struct inode *inode, struct file *file,
1262 goto out; 1262 goto out;
1263 } 1263 }
1264 1264
1265 for (i = 0; i < tvps->num; i++) 1265 for (i = 0; i < tvps->num; i++) {
1266 err |= dtv_property_process_set(fe, tvp + i, inode, file); 1266 (tvp + i)->result = dtv_property_process_set(fe, tvp + i, inode, file);
1267 err |= (tvp + i)->result;
1268 }
1267 1269
1268 if(fe->dtv_property_cache.state == DTV_TUNE) { 1270 if(fe->dtv_property_cache.state == DTV_TUNE) {
1269 printk("%s() Property cache is full, tuning\n", __FUNCTION__); 1271 printk("%s() Property cache is full, tuning\n", __FUNCTION__);
@@ -1295,8 +1297,10 @@ static int dvb_frontend_ioctl_properties(struct inode *inode, struct file *file,
1295 goto out; 1297 goto out;
1296 } 1298 }
1297 1299
1298 for (i = 0; i < tvps->num; i++) 1300 for (i = 0; i < tvps->num; i++) {
1299 err |= dtv_property_process_get(fe, tvp + i, inode, file); 1301 (tvp + i)->result = dtv_property_process_get(fe, tvp + i, inode, file);
1302 err |= (tvp + i)->result;
1303 }
1300 1304
1301 if (copy_to_user(tvps->props, tvp, tvps->num * sizeof(struct dtv_property))) { 1305 if (copy_to_user(tvps->props, tvp, tvps->num * sizeof(struct dtv_property))) {
1302 err = -EFAULT; 1306 err = -EFAULT;