1
0
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:
Ralph Metzler 2018-03-22 19:36:08 +01:00
parent 9acbf467ec
commit e0fdedbef3
2 changed files with 78 additions and 74 deletions

View File

@ -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)

View File

@ -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];