Commit 84409a95 authored by Daniel Scheller's avatar Daniel Scheller Committed by Mauro Carvalho Chehab

media: ddbridge/mci: make ddb_mci_cmd() and ddb_mci_config() public

In preparation for splitting all MaxSX8 related code parts from the common
MCI code, prefix both mci_cmd() and mci_config() functions with ddb_,
remove the static marking and add matching function prototypes to
ddbridge-mci.h so these functions can be reused from other files within
the ddbridge driver. As this requires the mci-related structs to be
defined in ddbridge-mci.h, move struct mci and struct mci_base there and
clean them up.

Picked up from the upstream dddvb GIT.
Signed-off-by: default avatarDaniel Scheller <d.scheller@gmx.net>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+samsung@kernel.org>
parent 07b12de2
...@@ -26,38 +26,6 @@ static const u32 MCLK = (1550000000 / 12); ...@@ -26,38 +26,6 @@ static const u32 MCLK = (1550000000 / 12);
static const u32 MAX_DEMOD_LDPC_BITRATE = (1550000000 / 6); static const u32 MAX_DEMOD_LDPC_BITRATE = (1550000000 / 6);
static const u32 MAX_LDPC_BITRATE = (720000000); static const u32 MAX_LDPC_BITRATE = (720000000);
struct mci_base {
struct list_head mci_list;
void *key;
struct ddb_link *link;
struct completion completion;
struct device *dev;
struct mutex tuner_lock; /* concurrent tuner access lock */
u8 adr;
struct mutex mci_lock; /* concurrent MCI access lock */
int count;
u8 tuner_use_count[MCI_TUNER_MAX];
u8 assigned_demod[MCI_DEMOD_MAX];
u32 used_ldpc_bitrate[MCI_DEMOD_MAX];
u8 demod_in_use[MCI_DEMOD_MAX];
u32 iq_mode;
};
struct mci {
struct mci_base *base;
struct dvb_frontend fe;
int nr;
int demod;
int tuner;
int first_time_lock;
int started;
struct mci_result signal_info;
u32 bb_mode;
};
static int mci_reset(struct mci *state) static int mci_reset(struct mci *state)
{ {
struct ddb_link *link = state->base->link; struct ddb_link *link = state->base->link;
...@@ -84,7 +52,7 @@ static int mci_reset(struct mci *state) ...@@ -84,7 +52,7 @@ static int mci_reset(struct mci *state)
return 0; return 0;
} }
static int mci_config(struct mci *state, u32 config) int ddb_mci_config(struct mci *state, u32 config)
{ {
struct ddb_link *link = state->base->link; struct ddb_link *link = state->base->link;
...@@ -122,7 +90,7 @@ static int _mci_cmd_unlocked(struct mci *state, ...@@ -122,7 +90,7 @@ static int _mci_cmd_unlocked(struct mci *state,
return 0; return 0;
} }
static int mci_cmd(struct mci *state, int ddb_mci_cmd(struct mci *state,
struct mci_command *command, struct mci_command *command,
struct mci_result *result) struct mci_result *result)
{ {
...@@ -164,7 +132,7 @@ static int get_info(struct dvb_frontend *fe) ...@@ -164,7 +132,7 @@ static int get_info(struct dvb_frontend *fe)
memset(&cmd, 0, sizeof(cmd)); memset(&cmd, 0, sizeof(cmd));
cmd.command = MCI_CMD_GETSIGNALINFO; cmd.command = MCI_CMD_GETSIGNALINFO;
cmd.demod = state->demod; cmd.demod = state->demod;
stat = mci_cmd(state, &cmd, &state->signal_info); stat = ddb_mci_cmd(state, &cmd, &state->signal_info);
return stat; return stat;
} }
...@@ -205,7 +173,7 @@ static int read_status(struct dvb_frontend *fe, enum fe_status *status) ...@@ -205,7 +173,7 @@ static int read_status(struct dvb_frontend *fe, enum fe_status *status)
cmd.command = MCI_CMD_GETSTATUS; cmd.command = MCI_CMD_GETSTATUS;
cmd.demod = state->demod; cmd.demod = state->demod;
stat = mci_cmd(state, &cmd, &res); stat = ddb_mci_cmd(state, &cmd, &res);
if (stat) if (stat)
return stat; return stat;
*status = 0x00; *status = 0x00;
...@@ -228,7 +196,7 @@ static int mci_set_tuner(struct dvb_frontend *fe, u32 tuner, u32 on) ...@@ -228,7 +196,7 @@ static int mci_set_tuner(struct dvb_frontend *fe, u32 tuner, u32 on)
memset(&cmd, 0, sizeof(cmd)); memset(&cmd, 0, sizeof(cmd));
cmd.tuner = state->tuner; cmd.tuner = state->tuner;
cmd.command = on ? SX8_CMD_INPUT_ENABLE : SX8_CMD_INPUT_DISABLE; cmd.command = on ? SX8_CMD_INPUT_ENABLE : SX8_CMD_INPUT_DISABLE;
return mci_cmd(state, &cmd, NULL); return ddb_mci_cmd(state, &cmd, NULL);
} }
static int stop(struct dvb_frontend *fe) static int stop(struct dvb_frontend *fe)
...@@ -241,13 +209,13 @@ static int stop(struct dvb_frontend *fe) ...@@ -241,13 +209,13 @@ static int stop(struct dvb_frontend *fe)
if (state->demod != DEMOD_UNUSED) { if (state->demod != DEMOD_UNUSED) {
cmd.command = MCI_CMD_STOP; cmd.command = MCI_CMD_STOP;
cmd.demod = state->demod; cmd.demod = state->demod;
mci_cmd(state, &cmd, NULL); ddb_mci_cmd(state, &cmd, NULL);
if (state->base->iq_mode) { if (state->base->iq_mode) {
cmd.command = MCI_CMD_STOP; cmd.command = MCI_CMD_STOP;
cmd.demod = state->demod; cmd.demod = state->demod;
cmd.output = 0; cmd.output = 0;
mci_cmd(state, &cmd, NULL); ddb_mci_cmd(state, &cmd, NULL);
mci_config(state, SX8_TSCONFIG_MODE_NORMAL); ddb_mci_config(state, SX8_TSCONFIG_MODE_NORMAL);
} }
} }
mutex_lock(&state->base->tuner_lock); mutex_lock(&state->base->tuner_lock);
...@@ -345,8 +313,8 @@ static int start(struct dvb_frontend *fe, u32 flags, u32 modmask, u32 ts_config) ...@@ -345,8 +313,8 @@ static int start(struct dvb_frontend *fe, u32 flags, u32 modmask, u32 ts_config)
cmd.command = SX8_CMD_ENABLE_IQOUTPUT; cmd.command = SX8_CMD_ENABLE_IQOUTPUT;
cmd.demod = state->demod; cmd.demod = state->demod;
cmd.output = 0; cmd.output = 0;
mci_cmd(state, &cmd, NULL); ddb_mci_cmd(state, &cmd, NULL);
mci_config(state, ts_config); ddb_mci_config(state, ts_config);
} }
if (p->stream_id != NO_STREAM_ID_FILTER && p->stream_id != 0x80000000) if (p->stream_id != NO_STREAM_ID_FILTER && p->stream_id != 0x80000000)
flags |= 0x80; flags |= 0x80;
...@@ -368,7 +336,7 @@ static int start(struct dvb_frontend *fe, u32 flags, u32 modmask, u32 ts_config) ...@@ -368,7 +336,7 @@ static int start(struct dvb_frontend *fe, u32 flags, u32 modmask, u32 ts_config)
cmd.output = state->nr; cmd.output = state->nr;
if (p->stream_id == 0x80000000) if (p->stream_id == 0x80000000)
cmd.output |= 0x80; cmd.output |= 0x80;
stat = mci_cmd(state, &cmd, NULL); stat = ddb_mci_cmd(state, &cmd, NULL);
if (stat) if (stat)
stop(fe); stop(fe);
return stat; return stat;
...@@ -413,8 +381,8 @@ static int start_iq(struct dvb_frontend *fe, u32 ts_config) ...@@ -413,8 +381,8 @@ static int start_iq(struct dvb_frontend *fe, u32 ts_config)
cmd.tuner = state->tuner; cmd.tuner = state->tuner;
cmd.demod = state->demod; cmd.demod = state->demod;
cmd.output = 7; cmd.output = 7;
mci_config(state, ts_config); ddb_mci_config(state, ts_config);
stat = mci_cmd(state, &cmd, NULL); stat = ddb_mci_cmd(state, &cmd, NULL);
if (stat) if (stat)
stop(fe); stop(fe);
return stat; return stat;
......
...@@ -206,6 +206,42 @@ struct mci_result { ...@@ -206,6 +206,42 @@ struct mci_result {
u32 version[4]; u32 version[4];
}; };
struct mci_base {
struct list_head mci_list;
void *key;
struct ddb_link *link;
struct completion completion;
struct device *dev;
struct mutex tuner_lock; /* concurrent tuner access lock */
u8 adr;
struct mutex mci_lock; /* concurrent MCI access lock */
int count;
u8 tuner_use_count[MCI_TUNER_MAX];
u8 assigned_demod[MCI_DEMOD_MAX];
u32 used_ldpc_bitrate[MCI_DEMOD_MAX];
u8 demod_in_use[MCI_DEMOD_MAX];
u32 iq_mode;
};
struct mci {
struct mci_base *base;
struct dvb_frontend fe;
int nr;
int demod;
int tuner;
int first_time_lock;
int started;
struct mci_result signal_info;
u32 bb_mode;
};
int ddb_mci_cmd(struct mci *state, struct mci_command *command,
struct mci_result *result);
int ddb_mci_config(struct mci *state, u32 config);
struct dvb_frontend struct dvb_frontend
*ddb_mci_attach(struct ddb_input *input, *ddb_mci_attach(struct ddb_input *input,
int mci_type, int nr, int mci_type, int nr,
......
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