mirror of
https://github.com/DigitalDevices/dddvb.git
synced 2023-10-10 13:37:43 +02:00
adjust to newer include files and firmware
This commit is contained in:
parent
9acbf467ec
commit
e0fdedbef3
@ -1,9 +1,9 @@
|
|||||||
/*
|
/*
|
||||||
* ddbridge-mci.c: Digital Devices microcode interface
|
* ddbridge-mci.c: Digital Devices microcode interface
|
||||||
*
|
*
|
||||||
* Copyright (C) 2017 Digital Devices GmbH
|
* Copyright (C) 2017-2018 Digital Devices GmbH
|
||||||
* Ralph Metzler <rjkm@metzlerbros.de>
|
* Ralph Metzler <rjkm@metzlerbros.de>
|
||||||
* Marcus Metzler <mocm@metzlerbros.de>
|
* Marcus Metzler <mocm@metzlerbros.de>
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or
|
* This program is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License
|
* modify it under the terms of the GNU General Public License
|
||||||
@ -238,6 +238,30 @@ static int get_info(struct dvb_frontend *fe)
|
|||||||
return stat;
|
return stat;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int get_snr(struct dvb_frontend *fe)
|
||||||
|
{
|
||||||
|
struct mci *state = fe->demodulator_priv;
|
||||||
|
struct dtv_frontend_properties *p = &fe->dtv_property_cache;
|
||||||
|
|
||||||
|
p->cnr.len = 1;
|
||||||
|
p->cnr.stat[0].scale = FE_SCALE_DECIBEL;
|
||||||
|
p->cnr.stat[0].svalue = (s64) state->signal_info.dvbs2_signal_info.signal_to_noise * 100;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int get_strength(struct dvb_frontend *fe)
|
||||||
|
{
|
||||||
|
struct mci *state = fe->demodulator_priv;
|
||||||
|
struct dtv_frontend_properties *p = &fe->dtv_property_cache;
|
||||||
|
s32 str;
|
||||||
|
|
||||||
|
str = 100000 - (state->signal_info.dvbs2_signal_info.channel_power * 10 + 108750);
|
||||||
|
p->strength.len = 1;
|
||||||
|
p->strength.stat[0].scale = FE_SCALE_DECIBEL;
|
||||||
|
p->strength.stat[0].svalue = str;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int read_status(struct dvb_frontend *fe, enum fe_status *status)
|
static int read_status(struct dvb_frontend *fe, enum fe_status *status)
|
||||||
{
|
{
|
||||||
int stat;
|
int stat;
|
||||||
@ -252,10 +276,14 @@ static int read_status(struct dvb_frontend *fe, enum fe_status *status)
|
|||||||
if (stat)
|
if (stat)
|
||||||
return stat;
|
return stat;
|
||||||
*status = 0x00;
|
*status = 0x00;
|
||||||
|
get_info(fe);
|
||||||
|
get_strength(fe);
|
||||||
if (res->status == SX8_DEMOD_WAIT_MATYPE)
|
if (res->status == SX8_DEMOD_WAIT_MATYPE)
|
||||||
*status = 0x0f;
|
*status = 0x0f;
|
||||||
if (res->status == SX8_DEMOD_LOCKED)
|
if (res->status == SX8_DEMOD_LOCKED) {
|
||||||
*status = 0x1f;
|
*status = 0x1f;
|
||||||
|
get_snr(fe);
|
||||||
|
}
|
||||||
return stat;
|
return stat;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -378,7 +406,7 @@ unlock:
|
|||||||
memset(&cmd, 0, sizeof(cmd));
|
memset(&cmd, 0, sizeof(cmd));
|
||||||
|
|
||||||
if (state->base->iq_mode) {
|
if (state->base->iq_mode) {
|
||||||
cmd.command = SX8_CMD_SELECT_IQOUT;
|
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);
|
mci_cmd(state, &cmd, NULL);
|
||||||
@ -412,8 +440,6 @@ static int start_iq(struct dvb_frontend *fe, u32 ts_config)
|
|||||||
{
|
{
|
||||||
struct mci *state = fe->demodulator_priv;
|
struct mci *state = fe->demodulator_priv;
|
||||||
struct dtv_frontend_properties *p = &fe->dtv_property_cache;
|
struct dtv_frontend_properties *p = &fe->dtv_property_cache;
|
||||||
static const u32 MAX_DEMOD_LDPC_BITRATE = (1550000000 / 6);
|
|
||||||
u32 used_ldpc_bitrate = 0, free_ldpc_bitrate;
|
|
||||||
u32 used_demods = 0;
|
u32 used_demods = 0;
|
||||||
struct mci_command cmd;
|
struct mci_command cmd;
|
||||||
u32 input = state->tuner;
|
u32 input = state->tuner;
|
||||||
@ -538,34 +564,6 @@ static int set_input(struct dvb_frontend *fe, int input)
|
|||||||
|
|
||||||
static int sleep(struct dvb_frontend *fe)
|
static int sleep(struct dvb_frontend *fe)
|
||||||
{
|
{
|
||||||
struct mci *state = fe->demodulator_priv;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
static int get_snr(struct dvb_frontend *fe)
|
|
||||||
{
|
|
||||||
struct mci *state = fe->demodulator_priv;
|
|
||||||
struct dtv_frontend_properties *p = &fe->dtv_property_cache;
|
|
||||||
s32 snr;
|
|
||||||
|
|
||||||
get_info(fe);
|
|
||||||
p->cnr.len = 1;
|
|
||||||
p->cnr.stat[0].scale = FE_SCALE_DECIBEL;
|
|
||||||
p->cnr.stat[0].svalue = (s64) state->signal_info.dvbs2_signal_info.signal_to_noise * 100;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int get_strength(struct dvb_frontend *fe)
|
|
||||||
{
|
|
||||||
struct mci *state = fe->demodulator_priv;
|
|
||||||
struct dtv_frontend_properties *p = &fe->dtv_property_cache;
|
|
||||||
s32 str;
|
|
||||||
|
|
||||||
get_info(fe);
|
|
||||||
str = 100000 - (state->signal_info.dvbs2_signal_info.channel_power * 10 + 108750);
|
|
||||||
p->strength.len = 1;
|
|
||||||
p->strength.stat[0].scale = FE_SCALE_DECIBEL;
|
|
||||||
p->strength.stat[0].svalue = str;
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -587,9 +585,10 @@ static struct dvb_frontend_ops mci_ops = {
|
|||||||
},
|
},
|
||||||
.get_frontend_algo = get_algo,
|
.get_frontend_algo = get_algo,
|
||||||
.tune = tune,
|
.tune = tune,
|
||||||
.release = release,
|
.release = release,
|
||||||
.read_status = read_status,
|
.read_status = read_status,
|
||||||
.set_input = set_input,
|
.set_input = set_input,
|
||||||
|
.sleep = sleep,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct mci_base *match_base(void *key)
|
static struct mci_base *match_base(void *key)
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
/*
|
/*
|
||||||
* ddbridge-mci.h: Digital Devices micro code interface
|
* ddbridge-mci.h: Digital Devices micro code interface
|
||||||
*
|
*
|
||||||
* Copyright (C) 2017 Digital Devices GmbH
|
* Copyright (C) 2017-2018 Digital Devices GmbH
|
||||||
* Marcus Metzler <mocm@metzlerbros.de>
|
* Marcus Metzler <mocm@metzlerbros.de>
|
||||||
* Ralph Metzler <rjkm@metzlerbros.de>
|
* Ralph Metzler <rjkm@metzlerbros.de>
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or
|
* This program is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License
|
* modify it under the terms of the GNU General Public License
|
||||||
@ -52,48 +52,53 @@
|
|||||||
#define SX8_TSCONFIG_BURSTSIZE_8K (0x00000020)
|
#define SX8_TSCONFIG_BURSTSIZE_8K (0x00000020)
|
||||||
#define SX8_TSCONFIG_BURSTSIZE_16K (0x00000030)
|
#define SX8_TSCONFIG_BURSTSIZE_16K (0x00000030)
|
||||||
|
|
||||||
#define SX8_DEMOD_STOPPED (0)
|
#define SX8_DEMOD_STOPPED (0)
|
||||||
#define SX8_DEMOD_IQ_MODE (1)
|
#define SX8_DEMOD_IQ_MODE (1)
|
||||||
#define SX8_DEMOD_WAIT_SIGNAL (2)
|
#define SX8_DEMOD_WAIT_SIGNAL (2)
|
||||||
#define SX8_DEMOD_WAIT_MATYPE (3)
|
#define SX8_DEMOD_WAIT_MATYPE (3)
|
||||||
#define SX8_DEMOD_TIMEOUT (14)
|
#define SX8_DEMOD_TIMEOUT (14)
|
||||||
#define SX8_DEMOD_LOCKED (15)
|
#define SX8_DEMOD_LOCKED (15)
|
||||||
|
|
||||||
#define MCI_CMD_STOP (0x01)
|
#define M4_DEMOD_STOPPED (0)
|
||||||
#define MCI_CMD_GETSTATUS (0x02)
|
#define M4_DEMOD_WAIT_SIGNAL (1)
|
||||||
#define MCI_CMD_GETSIGNALINFO (0x03)
|
#define M4_DEMOD_TIMEOUT (14)
|
||||||
#define MCI_CMD_RFPOWER (0x04)
|
#define M4_DEMOD_LOCKED (15)
|
||||||
|
|
||||||
#define MCI_CMD_SEARCH_DVBS (0x10)
|
#define MCI_CMD_STOP (0x01)
|
||||||
|
#define MCI_CMD_GETSTATUS (0x02)
|
||||||
|
#define MCI_CMD_GETSIGNALINFO (0x03)
|
||||||
|
#define MCI_CMD_RFPOWER (0x04)
|
||||||
|
|
||||||
#define MCI_CMD_GET_IQSYMBOL (0x30)
|
#define MCI_CMD_SEARCH_DVBS (0x10)
|
||||||
|
|
||||||
#define SX8_CMD_INPUT_ENABLE (0x40)
|
#define MCI_CMD_GET_IQSYMBOL (0x30)
|
||||||
#define SX8_CMD_INPUT_DISABLE (0x41)
|
|
||||||
#define SX8_CMD_START_IQ (0x42)
|
|
||||||
#define SX8_CMD_STOP_IQ (0x43)
|
|
||||||
#define SX8_CMD_SELECT_IQOUT (0x44)
|
|
||||||
#define SX8_CMD_SELECT_TSOUT (0x45)
|
|
||||||
|
|
||||||
#define SX8_ERROR_UNSUPPORTED (0x80)
|
#define SX8_CMD_INPUT_ENABLE (0x40)
|
||||||
|
#define SX8_CMD_INPUT_DISABLE (0x41)
|
||||||
|
#define SX8_CMD_START_IQ (0x42)
|
||||||
|
#define SX8_CMD_STOP_IQ (0x43)
|
||||||
|
#define SX8_CMD_ENABLE_IQOUTPUT (0x44)
|
||||||
|
#define SX8_CMD_DISABLE_IQOUTPUT (0x45)
|
||||||
|
|
||||||
#define SX8_SUCCESS(status) (status < SX8_ERROR_UNSUPPORTED)
|
#define MCI_ERROR_UNSUPPORTED (0x80)
|
||||||
|
|
||||||
#define SX8_CMD_DIAG_READ8 (0xE0)
|
#define MCI_SUCCESS(status) (status < MCI_ERROR_UNSUPPORTED)
|
||||||
#define SX8_CMD_DIAG_READ32 (0xE1)
|
|
||||||
#define SX8_CMD_DIAG_WRITE8 (0xE2)
|
|
||||||
#define SX8_CMD_DIAG_WRITE32 (0xE3)
|
|
||||||
|
|
||||||
#define M4_CMD_DIAG_READRF (0xE8)
|
#define SX8_CMD_DIAG_READ8 (0xE0)
|
||||||
#define M4_CMD_DIAG_WRITERF (0xE9)
|
#define SX8_CMD_DIAG_READ32 (0xE1)
|
||||||
|
#define SX8_CMD_DIAG_WRITE8 (0xE2)
|
||||||
|
#define SX8_CMD_DIAG_WRITE32 (0xE3)
|
||||||
|
|
||||||
#define M4_CMD_DIAG_READX (0xE0)
|
#define M4_CMD_DIAG_READRF (0xE8)
|
||||||
#define M4_CMD_DIAG_READT (0xE1)
|
#define M4_CMD_DIAG_WRITERF (0xE9)
|
||||||
#define M4_CMD_DIAG_WRITEX (0xE2)
|
|
||||||
#define M4_CMD_DIAG_WRITET (0xE3)
|
|
||||||
|
|
||||||
#define M4_CMD_DIAG_READRF (0xE8)
|
#define M4_CMD_DIAG_READX (0xE0)
|
||||||
#define M4_CMD_DIAG_WRITERF (0xE9)
|
#define M4_CMD_DIAG_READT (0xE1)
|
||||||
|
#define M4_CMD_DIAG_WRITEX (0xE2)
|
||||||
|
#define M4_CMD_DIAG_WRITET (0xE3)
|
||||||
|
|
||||||
|
#define M4_CMD_DIAG_READRF (0xE8)
|
||||||
|
#define M4_CMD_DIAG_WRITERF (0xE9)
|
||||||
|
|
||||||
|
|
||||||
struct mci_command {
|
struct mci_command {
|
||||||
@ -149,8 +154,8 @@ struct mci_result {
|
|||||||
u32 ber_denominator;
|
u32 ber_denominator;
|
||||||
} dvbs2_signal_info;
|
} dvbs2_signal_info;
|
||||||
struct {
|
struct {
|
||||||
u8 i_symbol;
|
s16 I;
|
||||||
u8 q_symbol;
|
s16 Q;
|
||||||
} dvbs2_signal_iq;
|
} dvbs2_signal_iq;
|
||||||
};
|
};
|
||||||
u32 version[4];
|
u32 version[4];
|
||||||
|
Loading…
Reference in New Issue
Block a user