mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-22 12:46:41 +07:00
336fea9229
Unfortunately, on devices that have multiple interfaces, udev->dev points to the parent device (usb) instead of the cx231xx specific one. Due to that the logs don't look too nice, as they'll print messages as if they were produced by USB core: usb-1-2: New device Conexant Corporation Polaris AV Capturb @ 480 Mbps (1554:5010) with 7 interfaces Instead of using the name of the parent device, let's use the name of the first cx231xx interface for all cx231xx sub-modules. With this path, the logs will be nicer: cx231xx 1-2:1.1: New device Conexant Corporation Polaris AV Capturb @ 480 Mbps (1554:5010) with 7 interfaces Signed-off-by: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
811 lines
21 KiB
C
811 lines
21 KiB
C
/*
|
|
cx231xx-pcb-config.c - driver for Conexant
|
|
Cx23100/101/102 USB video capture devices
|
|
|
|
Copyright (C) 2008 <srinivasa.deevi at conexant dot com>
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
*/
|
|
|
|
#include "cx231xx.h"
|
|
#include "cx231xx-conf-reg.h"
|
|
|
|
static unsigned int pcb_debug;
|
|
module_param(pcb_debug, int, 0644);
|
|
MODULE_PARM_DESC(pcb_debug, "enable pcb config debug messages [video]");
|
|
|
|
/******************************************************************************/
|
|
|
|
static struct pcb_config cx231xx_Scenario[] = {
|
|
{
|
|
INDEX_SELFPOWER_DIGITAL_ONLY, /* index */
|
|
USB_SELF_POWER, /* power_type */
|
|
0, /* speed , not decide yet */
|
|
MOD_DIGITAL, /* mode */
|
|
SOURCE_TS_BDA, /* ts1_source, digital tv only */
|
|
NOT_SUPPORTED, /* ts2_source */
|
|
NOT_SUPPORTED, /* analog source */
|
|
|
|
0, /* digital_index */
|
|
0, /* analog index */
|
|
0, /* dif_index */
|
|
0, /* external_index */
|
|
|
|
1, /* only one configuration */
|
|
{
|
|
{
|
|
0, /* config index */
|
|
{
|
|
0, /* interrupt ep index */
|
|
1, /* ts1 index */
|
|
NOT_SUPPORTED, /* TS2 index */
|
|
NOT_SUPPORTED, /* AUDIO */
|
|
NOT_SUPPORTED, /* VIDEO */
|
|
NOT_SUPPORTED, /* VANC */
|
|
NOT_SUPPORTED, /* HANC */
|
|
NOT_SUPPORTED /* ir_index */
|
|
}
|
|
,
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
}
|
|
,
|
|
/* full-speed config */
|
|
{
|
|
{
|
|
0, /* config index */
|
|
{
|
|
0, /* interrupt ep index */
|
|
1, /* ts1 index */
|
|
NOT_SUPPORTED, /* TS2 index */
|
|
NOT_SUPPORTED, /* AUDIO */
|
|
NOT_SUPPORTED, /* VIDEO */
|
|
NOT_SUPPORTED, /* VANC */
|
|
NOT_SUPPORTED, /* HANC */
|
|
NOT_SUPPORTED /* ir_index */
|
|
}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
}
|
|
}
|
|
,
|
|
|
|
{
|
|
INDEX_SELFPOWER_DUAL_DIGITAL, /* index */
|
|
USB_SELF_POWER, /* power_type */
|
|
0, /* speed , not decide yet */
|
|
MOD_DIGITAL, /* mode */
|
|
SOURCE_TS_BDA, /* ts1_source, digital tv only */
|
|
0, /* ts2_source,need update from register */
|
|
NOT_SUPPORTED, /* analog source */
|
|
0, /* digital_index */
|
|
0, /* analog index */
|
|
0, /* dif_index */
|
|
0, /* external_index */
|
|
|
|
1, /* only one configuration */
|
|
{
|
|
{
|
|
0, /* config index */
|
|
{
|
|
0, /* interrupt ep index */
|
|
1, /* ts1 index */
|
|
2, /* TS2 index */
|
|
NOT_SUPPORTED, /* AUDIO */
|
|
NOT_SUPPORTED, /* VIDEO */
|
|
NOT_SUPPORTED, /* VANC */
|
|
NOT_SUPPORTED, /* HANC */
|
|
NOT_SUPPORTED /* ir_index */
|
|
}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
}
|
|
,
|
|
/* full-speed */
|
|
{
|
|
{
|
|
0, /* config index */
|
|
{
|
|
0, /* interrupt ep index */
|
|
1, /* ts1 index */
|
|
2, /* TS2 index */
|
|
NOT_SUPPORTED, /* AUDIO */
|
|
NOT_SUPPORTED, /* VIDEO */
|
|
NOT_SUPPORTED, /* VANC */
|
|
NOT_SUPPORTED, /* HANC */
|
|
NOT_SUPPORTED /* ir_index */
|
|
}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
}
|
|
}
|
|
,
|
|
|
|
{
|
|
INDEX_SELFPOWER_ANALOG_ONLY, /* index */
|
|
USB_SELF_POWER, /* power_type */
|
|
0, /* speed , not decide yet */
|
|
MOD_ANALOG | MOD_DIF | MOD_EXTERNAL, /* mode ,analog tv only */
|
|
NOT_SUPPORTED, /* ts1_source, NOT SUPPORT */
|
|
NOT_SUPPORTED, /* ts2_source,NOT SUPPORT */
|
|
0, /* analog source, need update */
|
|
|
|
0, /* digital_index */
|
|
0, /* analog index */
|
|
0, /* dif_index */
|
|
0, /* external_index */
|
|
|
|
1, /* only one configuration */
|
|
{
|
|
{
|
|
0, /* config index */
|
|
{
|
|
0, /* interrupt ep index */
|
|
NOT_SUPPORTED, /* ts1 index */
|
|
NOT_SUPPORTED, /* TS2 index */
|
|
1, /* AUDIO */
|
|
2, /* VIDEO */
|
|
3, /* VANC */
|
|
4, /* HANC */
|
|
NOT_SUPPORTED /* ir_index */
|
|
}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
}
|
|
,
|
|
/* full-speed */
|
|
{
|
|
{
|
|
0, /* config index */
|
|
{
|
|
0, /* interrupt ep index */
|
|
NOT_SUPPORTED, /* ts1 index */
|
|
NOT_SUPPORTED, /* TS2 index */
|
|
1, /* AUDIO */
|
|
2, /* VIDEO */
|
|
NOT_SUPPORTED, /* VANC */
|
|
NOT_SUPPORTED, /* HANC */
|
|
NOT_SUPPORTED /* ir_index */
|
|
}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
}
|
|
}
|
|
,
|
|
|
|
{
|
|
INDEX_SELFPOWER_DUAL, /* index */
|
|
USB_SELF_POWER, /* power_type */
|
|
0, /* speed , not decide yet */
|
|
/* mode ,analog tv and digital path */
|
|
MOD_ANALOG | MOD_DIF | MOD_DIGITAL | MOD_EXTERNAL,
|
|
0, /* ts1_source,will update in register */
|
|
NOT_SUPPORTED, /* ts2_source,NOT SUPPORT */
|
|
0, /* analog source need update */
|
|
0, /* digital_index */
|
|
0, /* analog index */
|
|
0, /* dif_index */
|
|
0, /* external_index */
|
|
1, /* only one configuration */
|
|
{
|
|
{
|
|
0, /* config index */
|
|
{
|
|
0, /* interrupt ep index */
|
|
1, /* ts1 index */
|
|
NOT_SUPPORTED, /* TS2 index */
|
|
2, /* AUDIO */
|
|
3, /* VIDEO */
|
|
4, /* VANC */
|
|
5, /* HANC */
|
|
NOT_SUPPORTED /* ir_index */
|
|
}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
}
|
|
,
|
|
/* full-speed */
|
|
{
|
|
{
|
|
0, /* config index */
|
|
{
|
|
0, /* interrupt ep index */
|
|
1, /* ts1 index */
|
|
NOT_SUPPORTED, /* TS2 index */
|
|
2, /* AUDIO */
|
|
3, /* VIDEO */
|
|
NOT_SUPPORTED, /* VANC */
|
|
NOT_SUPPORTED, /* HANC */
|
|
NOT_SUPPORTED /* ir_index */
|
|
}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
}
|
|
}
|
|
,
|
|
|
|
{
|
|
INDEX_SELFPOWER_TRIPLE, /* index */
|
|
USB_SELF_POWER, /* power_type */
|
|
0, /* speed , not decide yet */
|
|
/* mode ,analog tv and digital path */
|
|
MOD_ANALOG | MOD_DIF | MOD_DIGITAL | MOD_EXTERNAL,
|
|
0, /* ts1_source, update in register */
|
|
0, /* ts2_source,update in register */
|
|
0, /* analog source, need update */
|
|
|
|
0, /* digital_index */
|
|
0, /* analog index */
|
|
0, /* dif_index */
|
|
0, /* external_index */
|
|
1, /* only one configuration */
|
|
{
|
|
{
|
|
0, /* config index */
|
|
{
|
|
0, /* interrupt ep index */
|
|
1, /* ts1 index */
|
|
2, /* TS2 index */
|
|
3, /* AUDIO */
|
|
4, /* VIDEO */
|
|
5, /* VANC */
|
|
6, /* HANC */
|
|
NOT_SUPPORTED /* ir_index */
|
|
}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
}
|
|
,
|
|
/* full-speed */
|
|
{
|
|
{
|
|
0, /* config index */
|
|
{
|
|
0, /* interrupt ep index */
|
|
1, /* ts1 index */
|
|
2, /* TS2 index */
|
|
3, /* AUDIO */
|
|
4, /* VIDEO */
|
|
NOT_SUPPORTED, /* VANC */
|
|
NOT_SUPPORTED, /* HANC */
|
|
NOT_SUPPORTED /* ir_index */
|
|
}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
}
|
|
}
|
|
,
|
|
|
|
{
|
|
INDEX_SELFPOWER_COMPRESSOR, /* index */
|
|
USB_SELF_POWER, /* power_type */
|
|
0, /* speed , not decide yet */
|
|
/* mode ,analog tv AND DIGITAL path */
|
|
MOD_ANALOG | MOD_DIF | MOD_DIGITAL | MOD_EXTERNAL,
|
|
NOT_SUPPORTED, /* ts1_source, disable */
|
|
SOURCE_TS_BDA, /* ts2_source */
|
|
0, /* analog source,need update */
|
|
0, /* digital_index */
|
|
0, /* analog index */
|
|
0, /* dif_index */
|
|
0, /* external_index */
|
|
1, /* only one configuration */
|
|
{
|
|
{
|
|
0, /* config index */
|
|
{
|
|
0, /* interrupt ep index */
|
|
NOT_SUPPORTED, /* ts1 index */
|
|
1, /* TS2 index */
|
|
2, /* AUDIO */
|
|
3, /* VIDEO */
|
|
4, /* VANC */
|
|
5, /* HANC */
|
|
NOT_SUPPORTED /* ir_index */
|
|
}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
}
|
|
,
|
|
/* full-speed */
|
|
{
|
|
{
|
|
0, /* config index */
|
|
{
|
|
0, /* interrupt ep index */
|
|
NOT_SUPPORTED, /* ts1 index */
|
|
1, /* TS2 index */
|
|
2, /* AUDIO */
|
|
3, /* VIDEO */
|
|
NOT_SUPPORTED, /* VANC */
|
|
NOT_SUPPORTED, /* HANC */
|
|
NOT_SUPPORTED /* ir_index */
|
|
}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
}
|
|
}
|
|
,
|
|
|
|
{
|
|
INDEX_BUSPOWER_DIGITAL_ONLY, /* index */
|
|
USB_BUS_POWER, /* power_type */
|
|
0, /* speed , not decide yet */
|
|
MOD_DIGITAL, /* mode ,analog tv AND DIGITAL path */
|
|
SOURCE_TS_BDA, /* ts1_source, disable */
|
|
NOT_SUPPORTED, /* ts2_source */
|
|
NOT_SUPPORTED, /* analog source */
|
|
|
|
0, /* digital_index */
|
|
0, /* analog index */
|
|
0, /* dif_index */
|
|
0, /* external_index */
|
|
|
|
1, /* only one configuration */
|
|
{
|
|
{
|
|
0, /* config index */
|
|
{
|
|
0, /* interrupt ep index = 2 */
|
|
1, /* ts1 index */
|
|
NOT_SUPPORTED, /* TS2 index */
|
|
NOT_SUPPORTED, /* AUDIO */
|
|
NOT_SUPPORTED, /* VIDEO */
|
|
NOT_SUPPORTED, /* VANC */
|
|
NOT_SUPPORTED, /* HANC */
|
|
NOT_SUPPORTED /* ir_index */
|
|
}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
}
|
|
,
|
|
/* full-speed */
|
|
{
|
|
{
|
|
0, /* config index */
|
|
{
|
|
0, /* interrupt ep index = 2 */
|
|
1, /* ts1 index */
|
|
NOT_SUPPORTED, /* TS2 index */
|
|
NOT_SUPPORTED, /* AUDIO */
|
|
NOT_SUPPORTED, /* VIDEO */
|
|
NOT_SUPPORTED, /* VANC */
|
|
NOT_SUPPORTED, /* HANC */
|
|
NOT_SUPPORTED /* ir_index */
|
|
}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
}
|
|
}
|
|
,
|
|
{
|
|
INDEX_BUSPOWER_ANALOG_ONLY, /* index */
|
|
USB_BUS_POWER, /* power_type */
|
|
0, /* speed , not decide yet */
|
|
MOD_ANALOG, /* mode ,analog tv AND DIGITAL path */
|
|
NOT_SUPPORTED, /* ts1_source, disable */
|
|
NOT_SUPPORTED, /* ts2_source */
|
|
SOURCE_ANALOG, /* analog source--analog */
|
|
0, /* digital_index */
|
|
0, /* analog index */
|
|
0, /* dif_index */
|
|
0, /* external_index */
|
|
1, /* only one configuration */
|
|
{
|
|
{
|
|
0, /* config index */
|
|
{
|
|
0, /* interrupt ep index */
|
|
NOT_SUPPORTED, /* ts1 index */
|
|
NOT_SUPPORTED, /* TS2 index */
|
|
1, /* AUDIO */
|
|
2, /* VIDEO */
|
|
3, /* VANC */
|
|
4, /* HANC */
|
|
NOT_SUPPORTED /* ir_index */
|
|
}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
}
|
|
,
|
|
{ /* full-speed */
|
|
{
|
|
0, /* config index */
|
|
{
|
|
0, /* interrupt ep index */
|
|
NOT_SUPPORTED, /* ts1 index */
|
|
NOT_SUPPORTED, /* TS2 index */
|
|
1, /* AUDIO */
|
|
2, /* VIDEO */
|
|
NOT_SUPPORTED, /* VANC */
|
|
NOT_SUPPORTED, /* HANC */
|
|
NOT_SUPPORTED /* ir_index */
|
|
}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
}
|
|
}
|
|
,
|
|
{
|
|
INDEX_BUSPOWER_DIF_ONLY, /* index */
|
|
USB_BUS_POWER, /* power_type */
|
|
0, /* speed , not decide yet */
|
|
/* mode ,analog tv AND DIGITAL path */
|
|
MOD_DIF | MOD_ANALOG | MOD_DIGITAL | MOD_EXTERNAL,
|
|
SOURCE_TS_BDA, /* ts1_source, disable */
|
|
NOT_SUPPORTED, /* ts2_source */
|
|
SOURCE_DIF | SOURCE_ANALOG | SOURCE_EXTERNAL, /* analog source, dif */
|
|
0, /* digital_index */
|
|
0, /* analog index */
|
|
0, /* dif_index */
|
|
0, /* external_index */
|
|
1, /* only one configuration */
|
|
{
|
|
{
|
|
0, /* config index */
|
|
{
|
|
0, /* interrupt ep index */
|
|
1, /* ts1 index */
|
|
NOT_SUPPORTED, /* TS2 index */
|
|
2, /* AUDIO */
|
|
3, /* VIDEO */
|
|
4, /* VANC */
|
|
5, /* HANC */
|
|
NOT_SUPPORTED /* ir_index */
|
|
}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
}
|
|
,
|
|
{ /* full speed */
|
|
{
|
|
0, /* config index */
|
|
{
|
|
0, /* interrupt ep index */
|
|
1, /* ts1 index */
|
|
NOT_SUPPORTED, /* TS2 index */
|
|
2, /* AUDIO */
|
|
3, /* VIDEO */
|
|
NOT_SUPPORTED, /* VANC */
|
|
NOT_SUPPORTED, /* HANC */
|
|
NOT_SUPPORTED /* ir_index */
|
|
}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
,
|
|
{NOT_SUPPORTED, {NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED, NOT_SUPPORTED, NOT_SUPPORTED,
|
|
NOT_SUPPORTED}
|
|
}
|
|
}
|
|
}
|
|
,
|
|
|
|
};
|
|
|
|
/*****************************************************************/
|
|
|
|
int initialize_cx231xx(struct cx231xx *dev)
|
|
{
|
|
int retval;
|
|
u32 config_info = 0;
|
|
struct pcb_config *p_pcb_info;
|
|
u8 usb_speed = 1; /* from register,1--HS, 0--FS */
|
|
u8 data[4] = { 0, 0, 0, 0 };
|
|
u32 ts1_source = 0;
|
|
u32 ts2_source = 0;
|
|
u32 analog_source = 0;
|
|
u8 _current_scenario_idx = 0xff;
|
|
|
|
ts1_source = SOURCE_TS_BDA;
|
|
ts2_source = SOURCE_TS_BDA;
|
|
|
|
/* read board config register to find out which
|
|
pcb config it is related to */
|
|
retval = cx231xx_read_ctrl_reg(dev, VRT_GET_REGISTER, BOARD_CFG_STAT,
|
|
data, 4);
|
|
if (retval < 0)
|
|
return retval;
|
|
|
|
config_info = le32_to_cpu(*((__le32 *)data));
|
|
usb_speed = (u8) (config_info & 0x1);
|
|
|
|
/* Verify this device belongs to Bus power or Self power device */
|
|
if (config_info & BUS_POWER) { /* bus-power */
|
|
switch (config_info & BUSPOWER_MASK) {
|
|
case TS1_PORT | BUS_POWER:
|
|
cx231xx_Scenario[INDEX_BUSPOWER_DIGITAL_ONLY].speed =
|
|
usb_speed;
|
|
p_pcb_info =
|
|
&cx231xx_Scenario[INDEX_BUSPOWER_DIGITAL_ONLY];
|
|
_current_scenario_idx = INDEX_BUSPOWER_DIGITAL_ONLY;
|
|
break;
|
|
case AVDEC_ENABLE | BUS_POWER:
|
|
cx231xx_Scenario[INDEX_BUSPOWER_ANALOG_ONLY].speed =
|
|
usb_speed;
|
|
p_pcb_info =
|
|
&cx231xx_Scenario[INDEX_BUSPOWER_ANALOG_ONLY];
|
|
_current_scenario_idx = INDEX_BUSPOWER_ANALOG_ONLY;
|
|
break;
|
|
case AVDEC_ENABLE | BUS_POWER | TS1_PORT:
|
|
cx231xx_Scenario[INDEX_BUSPOWER_DIF_ONLY].speed =
|
|
usb_speed;
|
|
p_pcb_info = &cx231xx_Scenario[INDEX_BUSPOWER_DIF_ONLY];
|
|
_current_scenario_idx = INDEX_BUSPOWER_DIF_ONLY;
|
|
break;
|
|
default:
|
|
dev_err(dev->dev,
|
|
"bad config in buspower!!!!\nconfig_info=%x\n",
|
|
config_info & BUSPOWER_MASK);
|
|
return 1;
|
|
}
|
|
} else { /* self-power */
|
|
|
|
switch (config_info & SELFPOWER_MASK) {
|
|
case TS1_PORT | SELF_POWER:
|
|
cx231xx_Scenario[INDEX_SELFPOWER_DIGITAL_ONLY].speed =
|
|
usb_speed;
|
|
p_pcb_info =
|
|
&cx231xx_Scenario[INDEX_SELFPOWER_DIGITAL_ONLY];
|
|
_current_scenario_idx = INDEX_SELFPOWER_DIGITAL_ONLY;
|
|
break;
|
|
case TS1_TS2_PORT | SELF_POWER:
|
|
cx231xx_Scenario[INDEX_SELFPOWER_DUAL_DIGITAL].speed =
|
|
usb_speed;
|
|
cx231xx_Scenario[INDEX_SELFPOWER_DUAL_DIGITAL].
|
|
ts2_source = ts2_source;
|
|
p_pcb_info =
|
|
&cx231xx_Scenario[INDEX_SELFPOWER_DUAL_DIGITAL];
|
|
_current_scenario_idx = INDEX_SELFPOWER_DUAL_DIGITAL;
|
|
break;
|
|
case AVDEC_ENABLE | SELF_POWER:
|
|
cx231xx_Scenario[INDEX_SELFPOWER_ANALOG_ONLY].speed =
|
|
usb_speed;
|
|
cx231xx_Scenario[INDEX_SELFPOWER_ANALOG_ONLY].
|
|
analog_source = analog_source;
|
|
p_pcb_info =
|
|
&cx231xx_Scenario[INDEX_SELFPOWER_ANALOG_ONLY];
|
|
_current_scenario_idx = INDEX_SELFPOWER_ANALOG_ONLY;
|
|
break;
|
|
case AVDEC_ENABLE | TS1_PORT | SELF_POWER:
|
|
cx231xx_Scenario[INDEX_SELFPOWER_DUAL].speed =
|
|
usb_speed;
|
|
cx231xx_Scenario[INDEX_SELFPOWER_DUAL].ts1_source =
|
|
ts1_source;
|
|
cx231xx_Scenario[INDEX_SELFPOWER_DUAL].analog_source =
|
|
analog_source;
|
|
p_pcb_info = &cx231xx_Scenario[INDEX_SELFPOWER_DUAL];
|
|
_current_scenario_idx = INDEX_SELFPOWER_DUAL;
|
|
break;
|
|
case AVDEC_ENABLE | TS1_TS2_PORT | SELF_POWER:
|
|
cx231xx_Scenario[INDEX_SELFPOWER_TRIPLE].speed =
|
|
usb_speed;
|
|
cx231xx_Scenario[INDEX_SELFPOWER_TRIPLE].ts1_source =
|
|
ts1_source;
|
|
cx231xx_Scenario[INDEX_SELFPOWER_TRIPLE].ts2_source =
|
|
ts2_source;
|
|
cx231xx_Scenario[INDEX_SELFPOWER_TRIPLE].analog_source =
|
|
analog_source;
|
|
p_pcb_info = &cx231xx_Scenario[INDEX_SELFPOWER_TRIPLE];
|
|
_current_scenario_idx = INDEX_SELFPOWER_TRIPLE;
|
|
break;
|
|
case AVDEC_ENABLE | TS1VIP_TS2_PORT | SELF_POWER:
|
|
cx231xx_Scenario[INDEX_SELFPOWER_COMPRESSOR].speed =
|
|
usb_speed;
|
|
cx231xx_Scenario[INDEX_SELFPOWER_COMPRESSOR].
|
|
analog_source = analog_source;
|
|
p_pcb_info =
|
|
&cx231xx_Scenario[INDEX_SELFPOWER_COMPRESSOR];
|
|
_current_scenario_idx = INDEX_SELFPOWER_COMPRESSOR;
|
|
break;
|
|
default:
|
|
dev_err(dev->dev,
|
|
"bad senario!!!!!\nconfig_info=%x\n",
|
|
config_info & SELFPOWER_MASK);
|
|
return -ENODEV;
|
|
}
|
|
}
|
|
|
|
dev->current_scenario_idx = _current_scenario_idx;
|
|
|
|
memcpy(&dev->current_pcb_config, p_pcb_info,
|
|
sizeof(struct pcb_config));
|
|
|
|
if (pcb_debug) {
|
|
dev_info(dev->dev,
|
|
"SC(0x00) register = 0x%x\n", config_info);
|
|
dev_info(dev->dev,
|
|
"scenario %d\n",
|
|
(dev->current_pcb_config.index) + 1);
|
|
dev_info(dev->dev,
|
|
"type=%x\n",
|
|
dev->current_pcb_config.type);
|
|
dev_info(dev->dev,
|
|
"mode=%x\n",
|
|
dev->current_pcb_config.mode);
|
|
dev_info(dev->dev,
|
|
"speed=%x\n",
|
|
dev->current_pcb_config.speed);
|
|
dev_info(dev->dev,
|
|
"ts1_source=%x\n",
|
|
dev->current_pcb_config.ts1_source);
|
|
dev_info(dev->dev,
|
|
"ts2_source=%x\n",
|
|
dev->current_pcb_config.ts2_source);
|
|
dev_info(dev->dev,
|
|
"analog_source=%x\n",
|
|
dev->current_pcb_config.analog_source);
|
|
}
|
|
|
|
return 0;
|
|
}
|