Commit 4d1f413e authored by HIRANO Takahito's avatar HIRANO Takahito Committed by Mauro Carvalho Chehab

V4L/DVB: pt1: Support Earthsoft PT2

Support Earthsoft PT2.
Signed-off-by: default avatarHIRANO Takahito <hiranotaka@zng.info>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent 2f790884
This diff is collapsed.
/* /*
* ISDB-S driver for VA1J5JF8007 * ISDB-S driver for VA1J5JF8007/VA1J5JF8011
* *
* Copyright (C) 2009 HIRANO Takahito <hiranotaka@zng.info> * Copyright (C) 2009 HIRANO Takahito <hiranotaka@zng.info>
* *
...@@ -580,7 +580,7 @@ static void va1j5jf8007s_release(struct dvb_frontend *fe) ...@@ -580,7 +580,7 @@ static void va1j5jf8007s_release(struct dvb_frontend *fe)
static struct dvb_frontend_ops va1j5jf8007s_ops = { static struct dvb_frontend_ops va1j5jf8007s_ops = {
.info = { .info = {
.name = "VA1J5JF8007 ISDB-S", .name = "VA1J5JF8007/VA1J5JF8011 ISDB-S",
.type = FE_QPSK, .type = FE_QPSK,
.frequency_min = 950000, .frequency_min = 950000,
.frequency_max = 2150000, .frequency_max = 2150000,
...@@ -628,28 +628,50 @@ static int va1j5jf8007s_prepare_1(struct va1j5jf8007s_state *state) ...@@ -628,28 +628,50 @@ static int va1j5jf8007s_prepare_1(struct va1j5jf8007s_state *state)
return 0; return 0;
} }
static const u8 va1j5jf8007s_prepare_bufs[][2] = { static const u8 va1j5jf8007s_20mhz_prepare_bufs[][2] = {
{0x04, 0x02}, {0x0d, 0x55}, {0x11, 0x40}, {0x13, 0x80}, {0x17, 0x01}, {0x04, 0x02}, {0x0d, 0x55}, {0x11, 0x40}, {0x13, 0x80}, {0x17, 0x01},
{0x1c, 0x0a}, {0x1d, 0xaa}, {0x1e, 0x20}, {0x1f, 0x88}, {0x51, 0xb0}, {0x1c, 0x0a}, {0x1d, 0xaa}, {0x1e, 0x20}, {0x1f, 0x88}, {0x51, 0xb0},
{0x52, 0x89}, {0x53, 0xb3}, {0x5a, 0x2d}, {0x5b, 0xd3}, {0x85, 0x69}, {0x52, 0x89}, {0x53, 0xb3}, {0x5a, 0x2d}, {0x5b, 0xd3}, {0x85, 0x69},
{0x87, 0x04}, {0x8e, 0x02}, {0xa3, 0xf7}, {0xa5, 0xc0}, {0x87, 0x04}, {0x8e, 0x02}, {0xa3, 0xf7}, {0xa5, 0xc0},
}; };
static const u8 va1j5jf8007s_25mhz_prepare_bufs[][2] = {
{0x04, 0x02}, {0x11, 0x40}, {0x13, 0x80}, {0x17, 0x01}, {0x1c, 0x0a},
{0x1d, 0xaa}, {0x1e, 0x20}, {0x1f, 0x88}, {0x51, 0xb0}, {0x52, 0x89},
{0x53, 0xb3}, {0x5a, 0x2d}, {0x5b, 0xd3}, {0x85, 0x69}, {0x87, 0x04},
{0x8e, 0x26}, {0xa3, 0xf7}, {0xa5, 0xc0},
};
static int va1j5jf8007s_prepare_2(struct va1j5jf8007s_state *state) static int va1j5jf8007s_prepare_2(struct va1j5jf8007s_state *state)
{ {
const u8 (*bufs)[2];
int size;
u8 addr; u8 addr;
u8 buf[2]; u8 buf[2];
struct i2c_msg msg; struct i2c_msg msg;
int i; int i;
switch (state->config->frequency) {
case VA1J5JF8007S_20MHZ:
bufs = va1j5jf8007s_20mhz_prepare_bufs;
size = ARRAY_SIZE(va1j5jf8007s_20mhz_prepare_bufs);
break;
case VA1J5JF8007S_25MHZ:
bufs = va1j5jf8007s_25mhz_prepare_bufs;
size = ARRAY_SIZE(va1j5jf8007s_25mhz_prepare_bufs);
break;
default:
return -EINVAL;
}
addr = state->config->demod_address; addr = state->config->demod_address;
msg.addr = addr; msg.addr = addr;
msg.flags = 0; msg.flags = 0;
msg.len = 2; msg.len = 2;
msg.buf = buf; msg.buf = buf;
for (i = 0; i < ARRAY_SIZE(va1j5jf8007s_prepare_bufs); i++) { for (i = 0; i < size; i++) {
memcpy(buf, va1j5jf8007s_prepare_bufs[i], sizeof(buf)); memcpy(buf, bufs[i], sizeof(buf));
if (i2c_transfer(state->adap, &msg, 1) != 1) if (i2c_transfer(state->adap, &msg, 1) != 1)
return -EREMOTEIO; return -EREMOTEIO;
} }
......
/* /*
* ISDB-S driver for VA1J5JF8007 * ISDB-S driver for VA1J5JF8007/VA1J5JF8011
* *
* Copyright (C) 2009 HIRANO Takahito <hiranotaka@zng.info> * Copyright (C) 2009 HIRANO Takahito <hiranotaka@zng.info>
* *
...@@ -24,8 +24,14 @@ ...@@ -24,8 +24,14 @@
#ifndef VA1J5JF8007S_H #ifndef VA1J5JF8007S_H
#define VA1J5JF8007S_H #define VA1J5JF8007S_H
enum va1j5jf8007s_frequency {
VA1J5JF8007S_20MHZ,
VA1J5JF8007S_25MHZ,
};
struct va1j5jf8007s_config { struct va1j5jf8007s_config {
u8 demod_address; u8 demod_address;
enum va1j5jf8007s_frequency frequency;
}; };
struct i2c_adapter; struct i2c_adapter;
......
/* /*
* ISDB-T driver for VA1J5JF8007 * ISDB-T driver for VA1J5JF8007/VA1J5JF8011
* *
* Copyright (C) 2009 HIRANO Takahito <hiranotaka@zng.info> * Copyright (C) 2009 HIRANO Takahito <hiranotaka@zng.info>
* *
...@@ -429,7 +429,7 @@ static void va1j5jf8007t_release(struct dvb_frontend *fe) ...@@ -429,7 +429,7 @@ static void va1j5jf8007t_release(struct dvb_frontend *fe)
static struct dvb_frontend_ops va1j5jf8007t_ops = { static struct dvb_frontend_ops va1j5jf8007t_ops = {
.info = { .info = {
.name = "VA1J5JF8007 ISDB-T", .name = "VA1J5JF8007/VA1J5JF8011 ISDB-T",
.type = FE_OFDM, .type = FE_OFDM,
.frequency_min = 90000000, .frequency_min = 90000000,
.frequency_max = 770000000, .frequency_max = 770000000,
...@@ -448,29 +448,50 @@ static struct dvb_frontend_ops va1j5jf8007t_ops = { ...@@ -448,29 +448,50 @@ static struct dvb_frontend_ops va1j5jf8007t_ops = {
.release = va1j5jf8007t_release, .release = va1j5jf8007t_release,
}; };
static const u8 va1j5jf8007t_prepare_bufs[][2] = { static const u8 va1j5jf8007t_20mhz_prepare_bufs[][2] = {
{0x03, 0x90}, {0x14, 0x8f}, {0x1c, 0x2a}, {0x1d, 0xa8}, {0x1e, 0xa2}, {0x03, 0x90}, {0x14, 0x8f}, {0x1c, 0x2a}, {0x1d, 0xa8}, {0x1e, 0xa2},
{0x22, 0x83}, {0x31, 0x0d}, {0x32, 0xe0}, {0x39, 0xd3}, {0x3a, 0x00}, {0x22, 0x83}, {0x31, 0x0d}, {0x32, 0xe0}, {0x39, 0xd3}, {0x3a, 0x00},
{0x5c, 0x40}, {0x5f, 0x80}, {0x75, 0x02}, {0x76, 0x4e}, {0x77, 0x03}, {0x5c, 0x40}, {0x5f, 0x80}, {0x75, 0x02}, {0x76, 0x4e}, {0x77, 0x03},
{0xef, 0x01} {0xef, 0x01}
}; };
static const u8 va1j5jf8007t_25mhz_prepare_bufs[][2] = {
{0x03, 0x90}, {0x1c, 0x2a}, {0x1d, 0xa8}, {0x1e, 0xa2}, {0x22, 0x83},
{0x3a, 0x00}, {0x5c, 0x40}, {0x5f, 0x80}, {0x75, 0x0a}, {0x76, 0x4c},
{0x77, 0x03}, {0xef, 0x01}
};
int va1j5jf8007t_prepare(struct dvb_frontend *fe) int va1j5jf8007t_prepare(struct dvb_frontend *fe)
{ {
struct va1j5jf8007t_state *state; struct va1j5jf8007t_state *state;
const u8 (*bufs)[2];
int size;
u8 buf[2]; u8 buf[2];
struct i2c_msg msg; struct i2c_msg msg;
int i; int i;
state = fe->demodulator_priv; state = fe->demodulator_priv;
switch (state->config->frequency) {
case VA1J5JF8007T_20MHZ:
bufs = va1j5jf8007t_20mhz_prepare_bufs;
size = ARRAY_SIZE(va1j5jf8007t_20mhz_prepare_bufs);
break;
case VA1J5JF8007T_25MHZ:
bufs = va1j5jf8007t_25mhz_prepare_bufs;
size = ARRAY_SIZE(va1j5jf8007t_25mhz_prepare_bufs);
break;
default:
return -EINVAL;
}
msg.addr = state->config->demod_address; msg.addr = state->config->demod_address;
msg.flags = 0; msg.flags = 0;
msg.len = sizeof(buf); msg.len = sizeof(buf);
msg.buf = buf; msg.buf = buf;
for (i = 0; i < ARRAY_SIZE(va1j5jf8007t_prepare_bufs); i++) { for (i = 0; i < size; i++) {
memcpy(buf, va1j5jf8007t_prepare_bufs[i], sizeof(buf)); memcpy(buf, bufs[i], sizeof(buf));
if (i2c_transfer(state->adap, &msg, 1) != 1) if (i2c_transfer(state->adap, &msg, 1) != 1)
return -EREMOTEIO; return -EREMOTEIO;
} }
......
/* /*
* ISDB-T driver for VA1J5JF8007 * ISDB-T driver for VA1J5JF8007/VA1J5JF8011
* *
* Copyright (C) 2009 HIRANO Takahito <hiranotaka@zng.info> * Copyright (C) 2009 HIRANO Takahito <hiranotaka@zng.info>
* *
...@@ -24,8 +24,14 @@ ...@@ -24,8 +24,14 @@
#ifndef VA1J5JF8007T_H #ifndef VA1J5JF8007T_H
#define VA1J5JF8007T_H #define VA1J5JF8007T_H
enum va1j5jf8007t_frequency {
VA1J5JF8007T_20MHZ,
VA1J5JF8007T_25MHZ,
};
struct va1j5jf8007t_config { struct va1j5jf8007t_config {
u8 demod_address; u8 demod_address;
enum va1j5jf8007t_frequency frequency;
}; };
struct i2c_adapter; struct i2c_adapter;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment