summaryrefslogtreecommitdiff
path: root/linux/drivers
diff options
context:
space:
mode:
Diffstat (limited to 'linux/drivers')
-rw-r--r--linux/drivers/media/video/pvrusb2/pvrusb2-std.c81
1 files changed, 55 insertions, 26 deletions
diff --git a/linux/drivers/media/video/pvrusb2/pvrusb2-std.c b/linux/drivers/media/video/pvrusb2/pvrusb2-std.c
index 857829120..64ba223c2 100644
--- a/linux/drivers/media/video/pvrusb2/pvrusb2-std.c
+++ b/linux/drivers/media/video/pvrusb2/pvrusb2-std.c
@@ -27,6 +27,7 @@ struct std_name {
v4l2_std_id id;
};
+
#define CSTD_PAL \
(V4L2_STD_PAL_B| \
V4L2_STD_PAL_B1| \
@@ -44,6 +45,7 @@ struct std_name {
#define CSTD_NTSC \
(V4L2_STD_NTSC_M| \
V4L2_STD_NTSC_M_JP| \
+ V4L2_STD_NTSC_M_KR| \
V4L2_STD_NTSC_443)
#define CSTD_SECAM \
@@ -66,10 +68,7 @@ struct std_name {
#define TSTD_K (V4L2_STD_PAL_K|V4L2_STD_SECAM_K)
#define TSTD_K1 (V4L2_STD_SECAM_K1)
#define TSTD_L (V4L2_STD_SECAM_L)
-#define TSTD_LC (V4L2_STD_SECAM_LC)
#define TSTD_M (V4L2_STD_PAL_M|V4L2_STD_NTSC_M)
-#define TSTD_Mj (V4L2_STD_NTSC_M_JP)
-#define TSTD_443 (V4L2_STD_NTSC_443)
#define TSTD_N (V4L2_STD_PAL_N)
#define TSTD_Nc (V4L2_STD_PAL_Nc)
#define TSTD_60 (V4L2_STD_PAL_60)
@@ -95,10 +94,11 @@ const static struct std_name std_items[] = {
{"K",TSTD_K},
{"K1",TSTD_K1},
{"L",TSTD_L},
- {"LC",TSTD_LC},
+ {"LC",V4L2_STD_SECAM_LC},
{"M",TSTD_M},
- {"Mj",TSTD_Mj},
- {"443",TSTD_443},
+ {"Mj",V4L2_STD_NTSC_M_JP},
+ {"443",V4L2_STD_NTSC_443},
+ {"Mk",V4L2_STD_NTSC_M_KR},
{"N",TSTD_N},
{"Nc",TSTD_Nc},
{"60",TSTD_60},
@@ -236,7 +236,7 @@ static struct v4l2_standard generic_standards[] = {
TSTD_I|
TSTD_K|TSTD_K1|
TSTD_L|
- TSTD_LC|
+ V4L2_STD_SECAM_LC |
TSTD_N|TSTD_Nc),
.frameperiod =
{
@@ -246,7 +246,9 @@ static struct v4l2_standard generic_standards[] = {
.framelines = 625,
.reserved = {0,0,0,0}
}, {
- .id = (TSTD_M|TSTD_Mj),
+ .id = (TSTD_M|
+ V4L2_STD_NTSC_M_JP|
+ V4L2_STD_NTSC_M_KR),
.frameperiod =
{
.numerator = 1001,
@@ -264,7 +266,7 @@ static struct v4l2_standard generic_standards[] = {
.framelines = 525,
.reserved = {0,0,0,0}
}, { // This is total wild guess
- .id = (TSTD_443),
+ .id = V4L2_STD_NTSC_443,
.frameperiod =
{
.numerator = 1001,
@@ -288,15 +290,40 @@ static struct v4l2_standard *match_std(v4l2_std_id id)
return 0;
}
+static int pvr2_std_fill(struct v4l2_standard *std,v4l2_std_id id)
+{
+ struct v4l2_standard *template;
+ int idx;
+ unsigned int bcnt;
+ template = match_std(id);
+ if (!template) return 0;
+ idx = std->index;
+ memcpy(std,template,sizeof(*template));
+ std->index = idx;
+ std->id = id;
+ bcnt = pvr2_std_id_to_str(std->name,sizeof(std->name)-1,id);
+ std->name[bcnt] = 0;
+ pvr2_trace(PVR2_TRACE_INIT,"Set up standard idx=%u name=%s",
+ std->index,std->name);
+ return !0;
+}
+
+/* These are special cases of combined standards that we should enumerate
+ separately if the component pieces are present. */
+static v4l2_std_id std_mixes[] = {
+ V4L2_STD_PAL_B | V4L2_STD_PAL_G,
+ V4L2_STD_PAL_D | V4L2_STD_PAL_K,
+ V4L2_STD_SECAM_B | V4L2_STD_SECAM_G,
+ V4L2_STD_SECAM_D | V4L2_STD_SECAM_K,
+};
+
struct v4l2_standard *pvr2_std_create_enum(unsigned int *countptr,
v4l2_std_id id)
{
unsigned int std_cnt = 0;
- unsigned int idx,bcnt;
+ unsigned int idx,bcnt,idx2;
v4l2_std_id idmsk,cmsk,fmsk;
struct v4l2_standard *stddefs;
- struct v4l2_standard *template;
- struct v4l2_standard *std;
if (pvrusb2_debug & PVR2_TRACE_INIT) {
char buf[50];
@@ -319,6 +346,10 @@ struct v4l2_standard *pvr2_std_create_enum(unsigned int *countptr,
fmsk |= idmsk;
}
+ for (idx2 = 0; idx2 < sizeof(std_mixes)/sizeof(std_mixes[0]); idx2++) {
+ if ((id & std_mixes[idx2]) == std_mixes[idx2]) std_cnt++;
+ }
+
if (fmsk) {
char buf[50];
bcnt = pvr2_std_id_to_str(buf,sizeof(buf),fmsk);
@@ -336,23 +367,21 @@ struct v4l2_standard *pvr2_std_create_enum(unsigned int *countptr,
stddefs = kmalloc(sizeof(struct v4l2_standard) * std_cnt,
GFP_KERNEL);
memset(stddefs,0,sizeof(struct v4l2_standard) * std_cnt);
+ for (idx = 0; idx < std_cnt; idx++) stddefs[idx].index = idx;
+
idx = 0;
- for (idmsk = 1, cmsk = id; cmsk; idmsk <<= 1) {
+
+ /* Enumerate potential special cases */
+ for (idx2 = 0; ((idx2 < sizeof(std_mixes)/sizeof(std_mixes[0])) &&
+ (idx < std_cnt)); idx2++) {
+ if (!(id & std_mixes[idx2])) continue;
+ if (pvr2_std_fill(stddefs+idx,std_mixes[idx2])) idx++;
+ }
+ /* Now enumerate individual pieces */
+ for (idmsk = 1, cmsk = id; cmsk && (idx < std_cnt); idmsk <<= 1) {
if (!(idmsk & cmsk)) continue;
cmsk &= ~idmsk;
- template = match_std(idmsk);
- if (!template) continue;
- if (idx >= std_cnt) break;
- std = stddefs+idx;
- memcpy(std,template,sizeof(*template));
- std->index = idx;
- std->id = idmsk;
- bcnt = pvr2_std_id_to_str(std->name,
- sizeof(std->name)-1,
- idmsk);
- std->name[bcnt] = 0;
- pvr2_trace(PVR2_TRACE_INIT,"Set up standard idx=%u name=%s",
- idx,std->name);
+ if (!pvr2_std_fill(stddefs+idx,idmsk)) continue;
idx++;
}