提交 08fe9f7d 编写于 作者: H Hans Verkuil 提交者: Mauro Carvalho Chehab

[media] cx231xx: remove g_chip_ident

Remove g_chip_ident and replace it with g_chip_info.
Signed-off-by: NHans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: NMauro Carvalho Chehab <mchehab@redhat.com>
上级 b1c85cc0
...@@ -1840,7 +1840,6 @@ static const struct v4l2_ioctl_ops mpeg_ioctl_ops = { ...@@ -1840,7 +1840,6 @@ static const struct v4l2_ioctl_ops mpeg_ioctl_ops = {
.vidioc_streamon = vidioc_streamon, .vidioc_streamon = vidioc_streamon,
.vidioc_streamoff = vidioc_streamoff, .vidioc_streamoff = vidioc_streamoff,
.vidioc_log_status = vidioc_log_status, .vidioc_log_status = vidioc_log_status,
.vidioc_g_chip_ident = cx231xx_g_chip_ident,
#ifdef CONFIG_VIDEO_ADV_DEBUG #ifdef CONFIG_VIDEO_ADV_DEBUG
.vidioc_g_register = cx231xx_g_register, .vidioc_g_register = cx231xx_g_register,
.vidioc_s_register = cx231xx_s_register, .vidioc_s_register = cx231xx_s_register,
......
...@@ -35,7 +35,6 @@ ...@@ -35,7 +35,6 @@
#include <media/v4l2-common.h> #include <media/v4l2-common.h>
#include <media/v4l2-ioctl.h> #include <media/v4l2-ioctl.h>
#include <media/v4l2-chip-ident.h>
#include "cx231xx.h" #include "cx231xx.h"
#include "cx231xx-dif.h" #include "cx231xx-dif.h"
......
...@@ -29,7 +29,6 @@ ...@@ -29,7 +29,6 @@
#include <media/tuner.h> #include <media/tuner.h>
#include <media/tveeprom.h> #include <media/tveeprom.h>
#include <media/v4l2-common.h> #include <media/v4l2-common.h>
#include <media/v4l2-chip-ident.h>
#include <media/cx25840.h> #include <media/cx25840.h>
#include "dvb-usb-ids.h" #include "dvb-usb-ids.h"
......
...@@ -32,7 +32,6 @@ ...@@ -32,7 +32,6 @@
#include <media/v4l2-common.h> #include <media/v4l2-common.h>
#include <media/v4l2-ioctl.h> #include <media/v4l2-ioctl.h>
#include <media/v4l2-chip-ident.h>
#include <media/msp3400.h> #include <media/msp3400.h>
#include <media/tuner.h> #include <media/tuner.h>
......
...@@ -36,7 +36,6 @@ ...@@ -36,7 +36,6 @@
#include <media/v4l2-common.h> #include <media/v4l2-common.h>
#include <media/v4l2-ioctl.h> #include <media/v4l2-ioctl.h>
#include <media/v4l2-event.h> #include <media/v4l2-event.h>
#include <media/v4l2-chip-ident.h>
#include <media/msp3400.h> #include <media/msp3400.h>
#include <media/tuner.h> #include <media/tuner.h>
...@@ -1228,45 +1227,45 @@ int cx231xx_s_frequency(struct file *file, void *priv, ...@@ -1228,45 +1227,45 @@ int cx231xx_s_frequency(struct file *file, void *priv,
return rc; return rc;
} }
int cx231xx_g_chip_ident(struct file *file, void *fh, #ifdef CONFIG_VIDEO_ADV_DEBUG
struct v4l2_dbg_chip_ident *chip)
int cx231xx_g_chip_info(struct file *file, void *fh,
struct v4l2_dbg_chip_info *chip)
{ {
chip->ident = V4L2_IDENT_NONE; switch (chip->match.addr) {
chip->revision = 0; case 0: /* Cx231xx - internal registers */
if (chip->match.type == V4L2_CHIP_MATCH_HOST) { return 0;
if (v4l2_chip_match_host(&chip->match)) case 1: /* AFE - read byte */
chip->ident = V4L2_IDENT_CX23100; strlcpy(chip->name, "AFE (byte)", sizeof(chip->name));
return 0;
case 2: /* Video Block - read byte */
strlcpy(chip->name, "Video (byte)", sizeof(chip->name));
return 0;
case 3: /* I2S block - read byte */
strlcpy(chip->name, "I2S (byte)", sizeof(chip->name));
return 0;
case 4: /* AFE - read dword */
strlcpy(chip->name, "AFE (dword)", sizeof(chip->name));
return 0;
case 5: /* Video Block - read dword */
strlcpy(chip->name, "Video (dword)", sizeof(chip->name));
return 0;
case 6: /* I2S Block - read dword */
strlcpy(chip->name, "I2S (dword)", sizeof(chip->name));
return 0; return 0;
} }
return -EINVAL; return -EINVAL;
} }
#ifdef CONFIG_VIDEO_ADV_DEBUG
/*
-R, --list-registers=type=<host/i2cdrv/i2caddr>,
chip=<chip>[,min=<addr>,max=<addr>]
dump registers from <min> to <max> [VIDIOC_DBG_G_REGISTER]
-r, --set-register=type=<host/i2cdrv/i2caddr>,
chip=<chip>,reg=<addr>,val=<val>
set the register [VIDIOC_DBG_S_REGISTER]
if type == host, then <chip> is the hosts chip ID (default 0)
if type == i2cdrv (default), then <chip> is the I2C driver name or ID
if type == i2caddr, then <chip> is the 7-bit I2C address
*/
int cx231xx_g_register(struct file *file, void *priv, int cx231xx_g_register(struct file *file, void *priv,
struct v4l2_dbg_register *reg) struct v4l2_dbg_register *reg)
{ {
struct cx231xx_fh *fh = priv; struct cx231xx_fh *fh = priv;
struct cx231xx *dev = fh->dev; struct cx231xx *dev = fh->dev;
int ret = 0; int ret;
u8 value[4] = { 0, 0, 0, 0 }; u8 value[4] = { 0, 0, 0, 0 };
u32 data = 0; u32 data = 0;
switch (reg->match.type) {
case V4L2_CHIP_MATCH_HOST:
switch (reg->match.addr) { switch (reg->match.addr) {
case 0: /* Cx231xx - internal registers */ case 0: /* Cx231xx - internal registers */
ret = cx231xx_read_ctrl_reg(dev, VRT_GET_REGISTER, ret = cx231xx_read_ctrl_reg(dev, VRT_GET_REGISTER,
...@@ -1277,130 +1276,37 @@ int cx231xx_g_register(struct file *file, void *priv, ...@@ -1277,130 +1276,37 @@ int cx231xx_g_register(struct file *file, void *priv,
case 1: /* AFE - read byte */ case 1: /* AFE - read byte */
ret = cx231xx_read_i2c_data(dev, AFE_DEVICE_ADDRESS, ret = cx231xx_read_i2c_data(dev, AFE_DEVICE_ADDRESS,
(u16)reg->reg, 2, &data, 1); (u16)reg->reg, 2, &data, 1);
reg->val = le32_to_cpu(data & 0xff); reg->val = data;
break;
case 14: /* AFE - read dword */
ret = cx231xx_read_i2c_data(dev, AFE_DEVICE_ADDRESS,
(u16)reg->reg, 2, &data, 4);
reg->val = le32_to_cpu(data);
break; break;
case 2: /* Video Block - read byte */ case 2: /* Video Block - read byte */
ret = cx231xx_read_i2c_data(dev, VID_BLK_I2C_ADDRESS, ret = cx231xx_read_i2c_data(dev, VID_BLK_I2C_ADDRESS,
(u16)reg->reg, 2, &data, 1); (u16)reg->reg, 2, &data, 1);
reg->val = le32_to_cpu(data & 0xff); reg->val = data;
break;
case 24: /* Video Block - read dword */
ret = cx231xx_read_i2c_data(dev, VID_BLK_I2C_ADDRESS,
(u16)reg->reg, 2, &data, 4);
reg->val = le32_to_cpu(data);
break; break;
case 3: /* I2S block - read byte */ case 3: /* I2S block - read byte */
ret = cx231xx_read_i2c_data(dev, ret = cx231xx_read_i2c_data(dev, I2S_BLK_DEVICE_ADDRESS,
I2S_BLK_DEVICE_ADDRESS, (u16)reg->reg, 1, &data, 1);
(u16)reg->reg, 1, reg->val = data;
&data, 1);
reg->val = le32_to_cpu(data & 0xff);
break; break;
case 34: /* I2S Block - read dword */ case 4: /* AFE - read dword */
ret = ret = cx231xx_read_i2c_data(dev, AFE_DEVICE_ADDRESS,
cx231xx_read_i2c_data(dev, I2S_BLK_DEVICE_ADDRESS, (u16)reg->reg, 2, &data, 4);
(u16)reg->reg, 1, &data, 4); reg->val = data;
reg->val = le32_to_cpu(data);
break;
}
return ret < 0 ? ret : 0;
case V4L2_CHIP_MATCH_I2C_DRIVER:
call_all(dev, core, g_register, reg);
return 0;
case V4L2_CHIP_MATCH_I2C_ADDR:/*for register debug*/
switch (reg->match.addr) {
case 0: /* Cx231xx - internal registers */
ret = cx231xx_read_ctrl_reg(dev, VRT_GET_REGISTER,
(u16)reg->reg, value, 4);
reg->val = value[0] | value[1] << 8 |
value[2] << 16 | value[3] << 24;
break;
case 0x600:/* AFE - read byte */
ret = cx231xx_read_i2c_master(dev, AFE_DEVICE_ADDRESS,
(u16)reg->reg, 2,
&data, 1 , 0);
reg->val = le32_to_cpu(data & 0xff);
break;
case 0x880:/* Video Block - read byte */
if (reg->reg < 0x0b) {
ret = cx231xx_read_i2c_master(dev,
VID_BLK_I2C_ADDRESS,
(u16)reg->reg, 2,
&data, 1 , 0);
reg->val = le32_to_cpu(data & 0xff);
} else {
ret = cx231xx_read_i2c_master(dev,
VID_BLK_I2C_ADDRESS,
(u16)reg->reg, 2,
&data, 4 , 0);
reg->val = le32_to_cpu(data);
}
break;
case 0x980:
ret = cx231xx_read_i2c_master(dev,
I2S_BLK_DEVICE_ADDRESS,
(u16)reg->reg, 1,
&data, 1 , 0);
reg->val = le32_to_cpu(data & 0xff);
break;
case 0x400:
ret =
cx231xx_read_i2c_master(dev, 0x40,
(u16)reg->reg, 1,
&data, 1 , 0);
reg->val = le32_to_cpu(data & 0xff);
break;
case 0xc01:
ret =
cx231xx_read_i2c_master(dev, 0xc0,
(u16)reg->reg, 2,
&data, 38, 1);
reg->val = le32_to_cpu(data);
break;
case 0x022:
ret =
cx231xx_read_i2c_master(dev, 0x02,
(u16)reg->reg, 1,
&data, 1, 2);
reg->val = le32_to_cpu(data & 0xff);
break;
case 0x322:
ret = cx231xx_read_i2c_master(dev,
0x32,
(u16)reg->reg, 1,
&data, 4 , 2);
reg->val = le32_to_cpu(data);
break; break;
case 0x342: case 5: /* Video Block - read dword */
ret = cx231xx_read_i2c_master(dev, ret = cx231xx_read_i2c_data(dev, VID_BLK_I2C_ADDRESS,
0x34, (u16)reg->reg, 2, &data, 4);
(u16)reg->reg, 1, reg->val = data;
&data, 4 , 2);
reg->val = le32_to_cpu(data);
break; break;
case 6: /* I2S Block - read dword */
default: ret = cx231xx_read_i2c_data(dev, I2S_BLK_DEVICE_ADDRESS,
cx231xx_info("no match device address!!\n"); (u16)reg->reg, 1, &data, 4);
reg->val = data;
break; break;
}
return ret < 0 ? ret : 0;
/*return -EINVAL;*/
default: default:
if (!v4l2_chip_match_host(&reg->match))
return -EINVAL; return -EINVAL;
} }
return ret < 0 ? ret : 0;
call_all(dev, core, g_register, reg);
return ret;
} }
int cx231xx_s_register(struct file *file, void *priv, int cx231xx_s_register(struct file *file, void *priv,
...@@ -1408,165 +1314,46 @@ int cx231xx_s_register(struct file *file, void *priv, ...@@ -1408,165 +1314,46 @@ int cx231xx_s_register(struct file *file, void *priv,
{ {
struct cx231xx_fh *fh = priv; struct cx231xx_fh *fh = priv;
struct cx231xx *dev = fh->dev; struct cx231xx *dev = fh->dev;
int ret = 0; int ret;
__le64 buf;
u32 value;
u8 data[4] = { 0, 0, 0, 0 }; u8 data[4] = { 0, 0, 0, 0 };
buf = cpu_to_le64(reg->val);
switch (reg->match.type) {
case V4L2_CHIP_MATCH_HOST:
{
value = (u32) buf & 0xffffffff;
switch (reg->match.addr) { switch (reg->match.addr) {
case 0: /* cx231xx internal registers */ case 0: /* cx231xx internal registers */
data[0] = (u8) value; data[0] = (u8) reg->val;
data[1] = (u8) (value >> 8); data[1] = (u8) (reg->val >> 8);
data[2] = (u8) (value >> 16); data[2] = (u8) (reg->val >> 16);
data[3] = (u8) (value >> 24); data[3] = (u8) (reg->val >> 24);
ret = cx231xx_write_ctrl_reg(dev, ret = cx231xx_write_ctrl_reg(dev, VRT_SET_REGISTER,
VRT_SET_REGISTER, (u16)reg->reg, data, 4);
(u16)reg->reg, data,
4);
break;
case 1: /* AFE - read byte */
ret = cx231xx_write_i2c_data(dev,
AFE_DEVICE_ADDRESS,
(u16)reg->reg, 2,
value, 1);
break; break;
case 14: /* AFE - read dword */ case 1: /* AFE - write byte */
ret = cx231xx_write_i2c_data(dev, ret = cx231xx_write_i2c_data(dev, AFE_DEVICE_ADDRESS,
AFE_DEVICE_ADDRESS, (u16)reg->reg, 2, reg->val, 1);
(u16)reg->reg, 2,
value, 4);
break; break;
case 2: /* Video Block - read byte */ case 2: /* Video Block - write byte */
ret = ret = cx231xx_write_i2c_data(dev, VID_BLK_I2C_ADDRESS,
cx231xx_write_i2c_data(dev, (u16)reg->reg, 2, reg->val, 1);
VID_BLK_I2C_ADDRESS,
(u16)reg->reg, 2,
value, 1);
break; break;
case 24: /* Video Block - read dword */ case 3: /* I2S block - write byte */
ret = ret = cx231xx_write_i2c_data(dev, I2S_BLK_DEVICE_ADDRESS,
cx231xx_write_i2c_data(dev, (u16)reg->reg, 1, reg->val, 1);
VID_BLK_I2C_ADDRESS,
(u16)reg->reg, 2,
value, 4);
break; break;
case 3: /* I2S block - read byte */ case 4: /* AFE - write dword */
ret = ret = cx231xx_write_i2c_data(dev, AFE_DEVICE_ADDRESS,
cx231xx_write_i2c_data(dev, (u16)reg->reg, 2, reg->val, 4);
I2S_BLK_DEVICE_ADDRESS,
(u16)reg->reg, 1,
value, 1);
break; break;
case 34: /* I2S block - read dword */ case 5: /* Video Block - write dword */
ret = ret = cx231xx_write_i2c_data(dev, VID_BLK_I2C_ADDRESS,
cx231xx_write_i2c_data(dev, (u16)reg->reg, 2, reg->val, 4);
I2S_BLK_DEVICE_ADDRESS,
(u16)reg->reg, 1,
value, 4);
break; break;
} case 6: /* I2S block - write dword */
} ret = cx231xx_write_i2c_data(dev, I2S_BLK_DEVICE_ADDRESS,
return ret < 0 ? ret : 0; (u16)reg->reg, 1, reg->val, 4);
case V4L2_CHIP_MATCH_I2C_ADDR:
{
value = (u32) buf & 0xffffffff;
switch (reg->match.addr) {
case 0:/*cx231xx internal registers*/
data[0] = (u8) value;
data[1] = (u8) (value >> 8);
data[2] = (u8) (value >> 16);
data[3] = (u8) (value >> 24);
ret = cx231xx_write_ctrl_reg(dev,
VRT_SET_REGISTER,
(u16)reg->reg, data,
4);
break;
case 0x600:/* AFE - read byte */
ret = cx231xx_write_i2c_master(dev,
AFE_DEVICE_ADDRESS,
(u16)reg->reg, 2,
value, 1 , 0);
break;
case 0x880:/* Video Block - read byte */
if (reg->reg < 0x0b)
cx231xx_write_i2c_master(dev,
VID_BLK_I2C_ADDRESS,
(u16)reg->reg, 2,
value, 1, 0);
else
cx231xx_write_i2c_master(dev,
VID_BLK_I2C_ADDRESS,
(u16)reg->reg, 2,
value, 4, 0);
break;
case 0x980:
ret =
cx231xx_write_i2c_master(dev,
I2S_BLK_DEVICE_ADDRESS,
(u16)reg->reg, 1,
value, 1, 0);
break;
case 0x400:
ret =
cx231xx_write_i2c_master(dev,
0x40,
(u16)reg->reg, 1,
value, 1, 0);
break;
case 0xc01:
ret =
cx231xx_write_i2c_master(dev,
0xc0,
(u16)reg->reg, 1,
value, 1, 1);
break;
case 0x022:
ret =
cx231xx_write_i2c_master(dev,
0x02,
(u16)reg->reg, 1,
value, 1, 2);
break;
case 0x322:
ret =
cx231xx_write_i2c_master(dev,
0x32,
(u16)reg->reg, 1,
value, 4, 2);
break;
case 0x342:
ret =
cx231xx_write_i2c_master(dev,
0x34,
(u16)reg->reg, 1,
value, 4, 2);
break; break;
default: default:
cx231xx_info("no match device address, " return -EINVAL;
"the value is %x\n", reg->match.addr);
break;
}
}
default:
break;
} }
return ret < 0 ? ret : 0;
call_all(dev, core, s_register, reg);
return ret;
} }
#endif #endif
...@@ -2208,8 +1995,8 @@ static const struct v4l2_ioctl_ops video_ioctl_ops = { ...@@ -2208,8 +1995,8 @@ static const struct v4l2_ioctl_ops video_ioctl_ops = {
.vidioc_s_tuner = cx231xx_s_tuner, .vidioc_s_tuner = cx231xx_s_tuner,
.vidioc_g_frequency = cx231xx_g_frequency, .vidioc_g_frequency = cx231xx_g_frequency,
.vidioc_s_frequency = cx231xx_s_frequency, .vidioc_s_frequency = cx231xx_s_frequency,
.vidioc_g_chip_ident = cx231xx_g_chip_ident,
#ifdef CONFIG_VIDEO_ADV_DEBUG #ifdef CONFIG_VIDEO_ADV_DEBUG
.vidioc_g_chip_info = cx231xx_g_chip_info,
.vidioc_g_register = cx231xx_g_register, .vidioc_g_register = cx231xx_g_register,
.vidioc_s_register = cx231xx_s_register, .vidioc_s_register = cx231xx_s_register,
#endif #endif
...@@ -2240,8 +2027,8 @@ static const struct v4l2_ioctl_ops radio_ioctl_ops = { ...@@ -2240,8 +2027,8 @@ static const struct v4l2_ioctl_ops radio_ioctl_ops = {
.vidioc_s_tuner = radio_s_tuner, .vidioc_s_tuner = radio_s_tuner,
.vidioc_g_frequency = cx231xx_g_frequency, .vidioc_g_frequency = cx231xx_g_frequency,
.vidioc_s_frequency = cx231xx_s_frequency, .vidioc_s_frequency = cx231xx_s_frequency,
.vidioc_g_chip_ident = cx231xx_g_chip_ident,
#ifdef CONFIG_VIDEO_ADV_DEBUG #ifdef CONFIG_VIDEO_ADV_DEBUG
.vidioc_g_chip_info = cx231xx_g_chip_info,
.vidioc_g_register = cx231xx_g_register, .vidioc_g_register = cx231xx_g_register,
.vidioc_s_register = cx231xx_s_register, .vidioc_s_register = cx231xx_s_register,
#endif #endif
......
...@@ -945,7 +945,7 @@ int cx231xx_enum_input(struct file *file, void *priv, ...@@ -945,7 +945,7 @@ int cx231xx_enum_input(struct file *file, void *priv,
struct v4l2_input *i); struct v4l2_input *i);
int cx231xx_g_input(struct file *file, void *priv, unsigned int *i); int cx231xx_g_input(struct file *file, void *priv, unsigned int *i);
int cx231xx_s_input(struct file *file, void *priv, unsigned int i); int cx231xx_s_input(struct file *file, void *priv, unsigned int i);
int cx231xx_g_chip_ident(struct file *file, void *fh, struct v4l2_dbg_chip_ident *chip); int cx231xx_g_chip_info(struct file *file, void *fh, struct v4l2_dbg_chip_info *chip);
int cx231xx_g_register(struct file *file, void *priv, int cx231xx_g_register(struct file *file, void *priv,
struct v4l2_dbg_register *reg); struct v4l2_dbg_register *reg);
int cx231xx_s_register(struct file *file, void *priv, int cx231xx_s_register(struct file *file, void *priv,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册