diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2013-02-24 17:35:10 -0800 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2013-02-24 17:35:10 -0800 | 
| commit | 21fbd5809ad126b949206d78e0a0e07ec872ea11 (patch) | |
| tree | a824045df99fc1f0690095a925cceb50207e332b /drivers/media/dvb-core/dvb_frontend.c | |
| parent | d9978ec5680059d727b39d6c706777c6973587f2 (diff) | |
| parent | ed72d37a33fdf43dc47787fe220532cdec9da528 (diff) | |
| download | olio-linux-3.10-21fbd5809ad126b949206d78e0a0e07ec872ea11.tar.xz olio-linux-3.10-21fbd5809ad126b949206d78e0a0e07ec872ea11.zip  | |
Merge branch 'v4l_for_linus' of git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-media
Pull media updates from Mauro Carvalho Chehab:
 - Some cleanups at V4L2 documentation
 - new drivers: ts2020 frontend, ov9650 sensor, s5c73m3 sensor,
   sh-mobile veu mem2mem driver, radio-ma901, davinci_vpfe staging
   driver
 - Lots of missing MAINTAINERS entries added
 - several em28xx driver improvements, including its conversion to
   videobuf2
 - several fixups on drivers to make them to better comply with the API
 - DVB core: add support for DVBv5 stats, allowing the implementation of
   statistics for new standards like ISDB
 - mb86a20s: add statistics to the driver
 - lots of new board additions, cleanups, and driver improvements.
* 'v4l_for_linus' of git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-media: (596 commits)
  [media] media: Add 0x3009 USB PID to ttusb2 driver (fixed diff)
  [media] rtl28xxu: Add USB IDs for Compro VideoMate U620F
  [media] em28xx: add usb id for terratec h5 rev. 3
  [media] media: rc: gpio-ir-recv: add support for device tree parsing
  [media] mceusb: move check earlier to make smatch happy
  [media] radio-si470x doc: add info about v4l2-ctl and sox+alsa
  [media] staging: media: Remove unnecessary OOM messages
  [media] sh_vou: Use vou_dev instead of vou_file wherever possible
  [media] sh_vou: Use video_drvdata()
  [media] drivers/media/platform/soc_camera/pxa_camera.c: use devm_ functions
  [media] mt9t112: mt9t111 format set up differs from mt9t112
  [media] sh-mobile-ceu-camera: fix SHARPNESS control default
  Revert "[media] fc0011: Return early, if the frequency is already tuned"
  [media] cx18/ivtv: fix regression: remove __init from a non-init function
  [media] em28xx: fix analog streaming with USB bulk transfers
  [media] stv0900: remove unnecessary null pointer check
  [media] fc0011: Return early, if the frequency is already tuned
  [media] fc0011: Add some sanity checks and cleanups
  [media] fc0011: Fix xin value clamping
  Revert "[media] [PATH,1/2] mxl5007 move reset to attach"
  ...
Diffstat (limited to 'drivers/media/dvb-core/dvb_frontend.c')
| -rw-r--r-- | drivers/media/dvb-core/dvb_frontend.c | 59 | 
1 files changed, 53 insertions, 6 deletions
diff --git a/drivers/media/dvb-core/dvb_frontend.c b/drivers/media/dvb-core/dvb_frontend.c index 0223ad255cb..6e50a758156 100644 --- a/drivers/media/dvb-core/dvb_frontend.c +++ b/drivers/media/dvb-core/dvb_frontend.c @@ -603,6 +603,7 @@ static int dvb_frontend_thread(void *data)  	enum dvbfe_algo algo;  	bool re_tune = false; +	bool semheld = false;  	dev_dbg(fe->dvb->device, "%s:\n", __func__); @@ -626,6 +627,8 @@ restart:  		if (kthread_should_stop() || dvb_frontend_is_exiting(fe)) {  			/* got signal or quitting */ +			if (!down_interruptible(&fepriv->sem)) +				semheld = true;  			fepriv->exit = DVB_FE_NORMAL_EXIT;  			break;  		} @@ -741,6 +744,8 @@ restart:  		fepriv->exit = DVB_FE_NO_EXIT;  	mb(); +	if (semheld) +		up(&fepriv->sem);  	dvb_frontend_wakeup(fe);  	return 0;  } @@ -1048,6 +1053,16 @@ static struct dtv_cmds_h dtv_cmds[DTV_MAX_COMMAND + 1] = {  	_DTV_CMD(DTV_ATSCMH_SCCC_CODE_MODE_B, 0, 0),  	_DTV_CMD(DTV_ATSCMH_SCCC_CODE_MODE_C, 0, 0),  	_DTV_CMD(DTV_ATSCMH_SCCC_CODE_MODE_D, 0, 0), + +	/* Statistics API */ +	_DTV_CMD(DTV_STAT_SIGNAL_STRENGTH, 0, 0), +	_DTV_CMD(DTV_STAT_CNR, 0, 0), +	_DTV_CMD(DTV_STAT_PRE_ERROR_BIT_COUNT, 0, 0), +	_DTV_CMD(DTV_STAT_PRE_TOTAL_BIT_COUNT, 0, 0), +	_DTV_CMD(DTV_STAT_POST_ERROR_BIT_COUNT, 0, 0), +	_DTV_CMD(DTV_STAT_POST_TOTAL_BIT_COUNT, 0, 0), +	_DTV_CMD(DTV_STAT_ERROR_BLOCK_COUNT, 0, 0), +	_DTV_CMD(DTV_STAT_TOTAL_BLOCK_COUNT, 0, 0),  };  static void dtv_property_dump(struct dvb_frontend *fe, struct dtv_property *tvp) @@ -1438,7 +1453,35 @@ static int dtv_property_process_get(struct dvb_frontend *fe,  		tvp->u.data = c->lna;  		break; +	/* Fill quality measures */ +	case DTV_STAT_SIGNAL_STRENGTH: +		tvp->u.st = c->strength; +		break; +	case DTV_STAT_CNR: +		tvp->u.st = c->cnr; +		break; +	case DTV_STAT_PRE_ERROR_BIT_COUNT: +		tvp->u.st = c->pre_bit_error; +		break; +	case DTV_STAT_PRE_TOTAL_BIT_COUNT: +		tvp->u.st = c->pre_bit_count; +		break; +	case DTV_STAT_POST_ERROR_BIT_COUNT: +		tvp->u.st = c->post_bit_error; +		break; +	case DTV_STAT_POST_TOTAL_BIT_COUNT: +		tvp->u.st = c->post_bit_count; +		break; +	case DTV_STAT_ERROR_BLOCK_COUNT: +		tvp->u.st = c->block_error; +		break; +	case DTV_STAT_TOTAL_BLOCK_COUNT: +		tvp->u.st = c->block_count; +		break;  	default: +		dev_dbg(fe->dvb->device, +			"%s: FE property %d doesn't exist\n", +			__func__, tvp->cmd);  		return -EINVAL;  	} @@ -1823,16 +1866,20 @@ static int dvb_frontend_ioctl(struct file *file,  	int err = -EOPNOTSUPP;  	dev_dbg(fe->dvb->device, "%s: (%d)\n", __func__, _IOC_NR(cmd)); -	if (fepriv->exit != DVB_FE_NO_EXIT) +	if (down_interruptible(&fepriv->sem)) +		return -ERESTARTSYS; + +	if (fepriv->exit != DVB_FE_NO_EXIT) { +		up(&fepriv->sem);  		return -ENODEV; +	}  	if ((file->f_flags & O_ACCMODE) == O_RDONLY &&  	    (_IOC_DIR(cmd) != _IOC_READ || cmd == FE_GET_EVENT || -	     cmd == FE_DISEQC_RECV_SLAVE_REPLY)) +	     cmd == FE_DISEQC_RECV_SLAVE_REPLY)) { +		up(&fepriv->sem);  		return -EPERM; - -	if (down_interruptible (&fepriv->sem)) -		return -ERESTARTSYS; +	}  	if ((cmd == FE_SET_PROPERTY) || (cmd == FE_GET_PROPERTY))  		err = dvb_frontend_ioctl_properties(file, cmd, parg); @@ -2246,7 +2293,7 @@ static int dvb_frontend_ioctl_legacy(struct file *file,  				printk("%s switch command: 0x%04lx\n", __func__, swcmd);  			do_gettimeofday(&nexttime);  			if (dvb_frontend_debug) -				memcpy(&tv[0], &nexttime, sizeof(struct timeval)); +				tv[0] = nexttime;  			/* before sending a command, initialize by sending  			 * a 32ms 18V to the switch  			 */  |