dbe82e0613
Patch generated with this script: for i in drivers/media/dvb-frontends/drx39xyj/*.[ch]; do perl -ne 's,(enum|struct|void|int|u32|u64|u16|u8|s8|s16|s32|s64)\s+(\S+)\s+\*[ ]+,\1 \2 *,g; print $_' <$i >a && mv a $i; done Acked-by: Devin Heitmueller <dheitmueller@kernellabs.com> Signed-off-by: Mauro Carvalho Chehab <m.chehab@samsung.com>
2937 lines
102 KiB
C
2937 lines
102 KiB
C
/*
|
|
Copyright (c), 2004-2005,2007-2010 Trident Microsystems, Inc.
|
|
All rights reserved.
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
modification, are permitted provided that the following conditions are met:
|
|
|
|
* Redistributions of source code must retain the above copyright notice,
|
|
this list of conditions and the following disclaimer.
|
|
* Redistributions in binary form must reproduce the above copyright notice,
|
|
this list of conditions and the following disclaimer in the documentation
|
|
and/or other materials provided with the distribution.
|
|
* Neither the name of Trident Microsystems nor Hauppauge Computer Works
|
|
nor the names of its contributors may be used to endorse or promote
|
|
products derived from this software without specific prior written
|
|
permission.
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
POSSIBILITY OF SUCH DAMAGE.
|
|
*/
|
|
|
|
/**
|
|
* \file $Id: drx_driver.h,v 1.84 2010/01/14 22:47:50 dingtao Exp $
|
|
*
|
|
* \brief DRX driver API
|
|
*
|
|
*/
|
|
#ifndef __DRXDRIVER_H__
|
|
#define __DRXDRIVER_H__
|
|
|
|
#include <linux/kernel.h>
|
|
/*-------------------------------------------------------------------------
|
|
INCLUDES
|
|
-------------------------------------------------------------------------*/
|
|
|
|
enum DRXStatus {
|
|
DRX_STS_READY = 3, /**< device/service is ready */
|
|
DRX_STS_BUSY = 2, /**< device/service is busy */
|
|
DRX_STS_OK = 1, /**< everything is OK */
|
|
DRX_STS_INVALID_ARG = -1,
|
|
/**< invalid arguments */
|
|
DRX_STS_ERROR = -2, /**< general error */
|
|
DRX_STS_FUNC_NOT_AVAILABLE = -3
|
|
/**< unavailable functionality */
|
|
};
|
|
|
|
/*
|
|
* This structure contains the I2C address, the device ID and a userData pointer.
|
|
* The userData pointer can be used for application specific purposes.
|
|
*/
|
|
struct i2c_device_addr {
|
|
u16 i2cAddr; /* The I2C address of the device. */
|
|
u16 i2cDevId; /* The device identifier. */
|
|
void *userData; /* User data pointer */
|
|
};
|
|
|
|
/**
|
|
* \def IS_I2C_10BIT( addr )
|
|
* \brief Determine if I2C address 'addr' is a 10 bits address or not.
|
|
* \param addr The I2C address.
|
|
* \return int.
|
|
* \retval 0 if address is not a 10 bits I2C address.
|
|
* \retval 1 if address is a 10 bits I2C address.
|
|
*/
|
|
#define IS_I2C_10BIT(addr) \
|
|
(((addr) & 0xF8) == 0xF0)
|
|
|
|
/*------------------------------------------------------------------------------
|
|
Exported FUNCTIONS
|
|
------------------------------------------------------------------------------*/
|
|
|
|
/**
|
|
* \fn DRXBSP_I2C_Init()
|
|
* \brief Initialize I2C communication module.
|
|
* \return int Return status.
|
|
* \retval DRX_STS_OK Initialization successful.
|
|
* \retval DRX_STS_ERROR Initialization failed.
|
|
*/
|
|
int DRXBSP_I2C_Init(void);
|
|
|
|
/**
|
|
* \fn DRXBSP_I2C_Term()
|
|
* \brief Terminate I2C communication module.
|
|
* \return int Return status.
|
|
* \retval DRX_STS_OK Termination successful.
|
|
* \retval DRX_STS_ERROR Termination failed.
|
|
*/
|
|
int DRXBSP_I2C_Term(void);
|
|
|
|
/**
|
|
* \fn int DRXBSP_I2C_WriteRead( struct i2c_device_addr *wDevAddr,
|
|
* u16 wCount,
|
|
* u8 * wData,
|
|
* struct i2c_device_addr *rDevAddr,
|
|
* u16 rCount,
|
|
* u8 * rData)
|
|
* \brief Read and/or write count bytes from I2C bus, store them in data[].
|
|
* \param wDevAddr The device i2c address and the device ID to write to
|
|
* \param wCount The number of bytes to write
|
|
* \param wData The array to write the data to
|
|
* \param rDevAddr The device i2c address and the device ID to read from
|
|
* \param rCount The number of bytes to read
|
|
* \param rData The array to read the data from
|
|
* \return int Return status.
|
|
* \retval DRX_STS_OK Succes.
|
|
* \retval DRX_STS_ERROR Failure.
|
|
* \retval DRX_STS_INVALID_ARG Parameter 'wcount' is not zero but parameter
|
|
* 'wdata' contains NULL.
|
|
* Idem for 'rcount' and 'rdata'.
|
|
* Both wDevAddr and rDevAddr are NULL.
|
|
*
|
|
* This function must implement an atomic write and/or read action on the I2C bus
|
|
* No other process may use the I2C bus when this function is executing.
|
|
* The critical section of this function runs from and including the I2C
|
|
* write, up to and including the I2C read action.
|
|
*
|
|
* The device ID can be useful if several devices share an I2C address.
|
|
* It can be used to control a "switch" on the I2C bus to the correct device.
|
|
*/
|
|
int DRXBSP_I2C_WriteRead(struct i2c_device_addr *wDevAddr,
|
|
u16 wCount,
|
|
u8 * wData,
|
|
struct i2c_device_addr *rDevAddr,
|
|
u16 rCount, u8 * rData);
|
|
|
|
/**
|
|
* \fn DRXBSP_I2C_ErrorText()
|
|
* \brief Returns a human readable error.
|
|
* Counter part of numerical DRX_I2C_Error_g.
|
|
*
|
|
* \return char* Pointer to human readable error text.
|
|
*/
|
|
char *DRXBSP_I2C_ErrorText(void);
|
|
|
|
/**
|
|
* \var DRX_I2C_Error_g;
|
|
* \brief I2C specific error codes, platform dependent.
|
|
*/
|
|
extern int DRX_I2C_Error_g;
|
|
|
|
#define TUNER_MODE_SUB0 0x0001 /* for sub-mode (e.g. RF-AGC setting) */
|
|
#define TUNER_MODE_SUB1 0x0002 /* for sub-mode (e.g. RF-AGC setting) */
|
|
#define TUNER_MODE_SUB2 0x0004 /* for sub-mode (e.g. RF-AGC setting) */
|
|
#define TUNER_MODE_SUB3 0x0008 /* for sub-mode (e.g. RF-AGC setting) */
|
|
#define TUNER_MODE_SUB4 0x0010 /* for sub-mode (e.g. RF-AGC setting) */
|
|
#define TUNER_MODE_SUB5 0x0020 /* for sub-mode (e.g. RF-AGC setting) */
|
|
#define TUNER_MODE_SUB6 0x0040 /* for sub-mode (e.g. RF-AGC setting) */
|
|
#define TUNER_MODE_SUB7 0x0080 /* for sub-mode (e.g. RF-AGC setting) */
|
|
|
|
#define TUNER_MODE_DIGITAL 0x0100 /* for digital channel (e.g. DVB-T) */
|
|
#define TUNER_MODE_ANALOG 0x0200 /* for analog channel (e.g. PAL) */
|
|
#define TUNER_MODE_SWITCH 0x0400 /* during channel switch & scanning */
|
|
#define TUNER_MODE_LOCK 0x0800 /* after tuner has locked */
|
|
#define TUNER_MODE_6MHZ 0x1000 /* for 6MHz bandwidth channels */
|
|
#define TUNER_MODE_7MHZ 0x2000 /* for 7MHz bandwidth channels */
|
|
#define TUNER_MODE_8MHZ 0x4000 /* for 8MHz bandwidth channels */
|
|
|
|
#define TUNER_MODE_SUB_MAX 8
|
|
#define TUNER_MODE_SUBALL ( TUNER_MODE_SUB0 | TUNER_MODE_SUB1 | \
|
|
TUNER_MODE_SUB2 | TUNER_MODE_SUB3 | \
|
|
TUNER_MODE_SUB4 | TUNER_MODE_SUB5 | \
|
|
TUNER_MODE_SUB6 | TUNER_MODE_SUB7 )
|
|
|
|
|
|
enum tuner_lock_status {
|
|
TUNER_LOCKED,
|
|
TUNER_NOT_LOCKED
|
|
};
|
|
|
|
struct tuner_common {
|
|
char *name; /* Tuner brand & type name */
|
|
s32 minFreqRF; /* Lowest RF input frequency, in kHz */
|
|
s32 maxFreqRF; /* Highest RF input frequency, in kHz */
|
|
|
|
u8 subMode; /* Index to sub-mode in use */
|
|
char *** subModeDescriptions; /* Pointer to description of sub-modes */
|
|
u8 subModes; /* Number of available sub-modes */
|
|
|
|
/* The following fields will be either 0, NULL or false and do not need
|
|
initialisation */
|
|
void *selfCheck; /* gives proof of initialization */
|
|
bool programmed; /* only valid if selfCheck is OK */
|
|
s32 RFfrequency; /* only valid if programmed */
|
|
s32 IFfrequency; /* only valid if programmed */
|
|
|
|
void *myUserData; /* pointer to associated demod instance */
|
|
u16 myCapabilities; /* value for storing application flags */
|
|
};
|
|
|
|
struct tuner_instance;
|
|
|
|
typedef int(*TUNEROpenFunc_t) (struct tuner_instance *tuner);
|
|
typedef int(*TUNERCloseFunc_t) (struct tuner_instance *tuner);
|
|
|
|
typedef int(*TUNERSetFrequencyFunc_t) (struct tuner_instance *tuner,
|
|
u32 mode,
|
|
s32
|
|
frequency);
|
|
|
|
typedef int(*TUNERGetFrequencyFunc_t) (struct tuner_instance *tuner,
|
|
u32 mode,
|
|
s32 *
|
|
RFfrequency,
|
|
s32 *
|
|
IFfrequency);
|
|
|
|
typedef int(*TUNERLockStatusFunc_t) (struct tuner_instance *tuner,
|
|
enum tuner_lock_status *
|
|
lockStat);
|
|
|
|
typedef int(*TUNERi2cWriteReadFunc_t) (struct tuner_instance *tuner,
|
|
struct i2c_device_addr *
|
|
wDevAddr, u16 wCount,
|
|
u8 * wData,
|
|
struct i2c_device_addr *
|
|
rDevAddr, u16 rCount,
|
|
u8 * rData);
|
|
|
|
struct tuner_ops {
|
|
TUNEROpenFunc_t openFunc;
|
|
TUNERCloseFunc_t closeFunc;
|
|
TUNERSetFrequencyFunc_t setFrequencyFunc;
|
|
TUNERGetFrequencyFunc_t getFrequencyFunc;
|
|
TUNERLockStatusFunc_t lockStatusFunc;
|
|
TUNERi2cWriteReadFunc_t i2cWriteReadFunc;
|
|
|
|
};
|
|
|
|
struct tuner_instance {
|
|
struct i2c_device_addr myI2CDevAddr;
|
|
struct tuner_common *myCommonAttr;
|
|
void *myExtAttr;
|
|
struct tuner_ops *myFunct;
|
|
};
|
|
|
|
|
|
int DRXBSP_TUNER_Open(struct tuner_instance *tuner);
|
|
|
|
int DRXBSP_TUNER_Close(struct tuner_instance *tuner);
|
|
|
|
int DRXBSP_TUNER_SetFrequency(struct tuner_instance *tuner,
|
|
u32 mode,
|
|
s32 frequency);
|
|
|
|
int DRXBSP_TUNER_GetFrequency(struct tuner_instance *tuner,
|
|
u32 mode,
|
|
s32 * RFfrequency,
|
|
s32 * IFfrequency);
|
|
|
|
int DRXBSP_TUNER_LockStatus(struct tuner_instance *tuner,
|
|
enum tuner_lock_status *lockStat);
|
|
|
|
int DRXBSP_TUNER_DefaultI2CWriteRead(struct tuner_instance *tuner,
|
|
struct i2c_device_addr *wDevAddr,
|
|
u16 wCount,
|
|
u8 * wData,
|
|
struct i2c_device_addr *rDevAddr,
|
|
u16 rCount, u8 * rData);
|
|
|
|
int DRXBSP_HST_Init(void);
|
|
|
|
int DRXBSP_HST_Term(void);
|
|
|
|
void *DRXBSP_HST_Memcpy(void *to, void *from, u32 n);
|
|
|
|
int DRXBSP_HST_Memcmp(void *s1, void *s2, u32 n);
|
|
|
|
u32 DRXBSP_HST_Clock(void);
|
|
|
|
int DRXBSP_HST_Sleep(u32 n);
|
|
|
|
|
|
|
|
/**************
|
|
*
|
|
* This section configures the DRX Data Access Protocols (DAPs).
|
|
*
|
|
**************/
|
|
|
|
/**
|
|
* \def DRXDAP_SINGLE_MASTER
|
|
* \brief Enable I2C single or I2C multimaster mode on host.
|
|
*
|
|
* Set to 1 to enable single master mode
|
|
* Set to 0 to enable multi master mode
|
|
*
|
|
* The actual DAP implementation may be restricted to only one of the modes.
|
|
* A compiler warning or error will be generated if the DAP implementation
|
|
* overides or cannot handle the mode defined below.
|
|
*
|
|
*/
|
|
#ifndef DRXDAP_SINGLE_MASTER
|
|
#define DRXDAP_SINGLE_MASTER 0
|
|
#endif
|
|
|
|
/**
|
|
* \def DRXDAP_MAX_WCHUNKSIZE
|
|
* \brief Defines maximum chunksize of an i2c write action by host.
|
|
*
|
|
* This indicates the maximum size of data the I2C device driver is able to
|
|
* write at a time. This includes I2C device address and register addressing.
|
|
*
|
|
* This maximum size may be restricted by the actual DAP implementation.
|
|
* A compiler warning or error will be generated if the DAP implementation
|
|
* overides or cannot handle the chunksize defined below.
|
|
*
|
|
* Beware that the DAP uses DRXDAP_MAX_WCHUNKSIZE to create a temporary data
|
|
* buffer. Do not undefine or choose too large, unless your system is able to
|
|
* handle a stack buffer of that size.
|
|
*
|
|
*/
|
|
#ifndef DRXDAP_MAX_WCHUNKSIZE
|
|
#define DRXDAP_MAX_WCHUNKSIZE 60
|
|
#endif
|
|
|
|
/**
|
|
* \def DRXDAP_MAX_RCHUNKSIZE
|
|
* \brief Defines maximum chunksize of an i2c read action by host.
|
|
*
|
|
* This indicates the maximum size of data the I2C device driver is able to read
|
|
* at a time. Minimum value is 2. Also, the read chunk size must be even.
|
|
*
|
|
* This maximum size may be restricted by the actual DAP implementation.
|
|
* A compiler warning or error will be generated if the DAP implementation
|
|
* overides or cannot handle the chunksize defined below.
|
|
*
|
|
*/
|
|
#ifndef DRXDAP_MAX_RCHUNKSIZE
|
|
#define DRXDAP_MAX_RCHUNKSIZE 60
|
|
#endif
|
|
|
|
/**************
|
|
*
|
|
* This section describes drxdriver defines.
|
|
*
|
|
**************/
|
|
|
|
/**
|
|
* \def DRX_UNKNOWN
|
|
* \brief Generic UNKNOWN value for DRX enumerated types.
|
|
*
|
|
* Used to indicate that the parameter value is unknown or not yet initalized.
|
|
*/
|
|
#ifndef DRX_UNKNOWN
|
|
#define DRX_UNKNOWN (254)
|
|
#endif
|
|
|
|
/**
|
|
* \def DRX_AUTO
|
|
* \brief Generic AUTO value for DRX enumerated types.
|
|
*
|
|
* Used to instruct the driver to automatically determine the value of the
|
|
* parameter.
|
|
*/
|
|
#ifndef DRX_AUTO
|
|
#define DRX_AUTO (255)
|
|
#endif
|
|
|
|
/**************
|
|
*
|
|
* This section describes flag definitions for the device capbilities.
|
|
*
|
|
**************/
|
|
|
|
/**
|
|
* \brief LNA capability flag
|
|
*
|
|
* Device has a Low Noise Amplifier
|
|
*
|
|
*/
|
|
#define DRX_CAPABILITY_HAS_LNA (1UL << 0)
|
|
/**
|
|
* \brief OOB-RX capability flag
|
|
*
|
|
* Device has OOB-RX
|
|
*
|
|
*/
|
|
#define DRX_CAPABILITY_HAS_OOBRX (1UL << 1)
|
|
/**
|
|
* \brief ATV capability flag
|
|
*
|
|
* Device has ATV
|
|
*
|
|
*/
|
|
#define DRX_CAPABILITY_HAS_ATV (1UL << 2)
|
|
/**
|
|
* \brief DVB-T capability flag
|
|
*
|
|
* Device has DVB-T
|
|
*
|
|
*/
|
|
#define DRX_CAPABILITY_HAS_DVBT (1UL << 3)
|
|
/**
|
|
* \brief ITU-B capability flag
|
|
*
|
|
* Device has ITU-B
|
|
*
|
|
*/
|
|
#define DRX_CAPABILITY_HAS_ITUB (1UL << 4)
|
|
/**
|
|
* \brief Audio capability flag
|
|
*
|
|
* Device has Audio
|
|
*
|
|
*/
|
|
#define DRX_CAPABILITY_HAS_AUD (1UL << 5)
|
|
/**
|
|
* \brief SAW switch capability flag
|
|
*
|
|
* Device has SAW switch
|
|
*
|
|
*/
|
|
#define DRX_CAPABILITY_HAS_SAWSW (1UL << 6)
|
|
/**
|
|
* \brief GPIO1 capability flag
|
|
*
|
|
* Device has GPIO1
|
|
*
|
|
*/
|
|
#define DRX_CAPABILITY_HAS_GPIO1 (1UL << 7)
|
|
/**
|
|
* \brief GPIO2 capability flag
|
|
*
|
|
* Device has GPIO2
|
|
*
|
|
*/
|
|
#define DRX_CAPABILITY_HAS_GPIO2 (1UL << 8)
|
|
/**
|
|
* \brief IRQN capability flag
|
|
*
|
|
* Device has IRQN
|
|
*
|
|
*/
|
|
#define DRX_CAPABILITY_HAS_IRQN (1UL << 9)
|
|
/**
|
|
* \brief 8VSB capability flag
|
|
*
|
|
* Device has 8VSB
|
|
*
|
|
*/
|
|
#define DRX_CAPABILITY_HAS_8VSB (1UL << 10)
|
|
/**
|
|
* \brief SMA-TX capability flag
|
|
*
|
|
* Device has SMATX
|
|
*
|
|
*/
|
|
#define DRX_CAPABILITY_HAS_SMATX (1UL << 11)
|
|
/**
|
|
* \brief SMA-RX capability flag
|
|
*
|
|
* Device has SMARX
|
|
*
|
|
*/
|
|
#define DRX_CAPABILITY_HAS_SMARX (1UL << 12)
|
|
/**
|
|
* \brief ITU-A/C capability flag
|
|
*
|
|
* Device has ITU-A/C
|
|
*
|
|
*/
|
|
#define DRX_CAPABILITY_HAS_ITUAC (1UL << 13)
|
|
|
|
/*-------------------------------------------------------------------------
|
|
MACROS
|
|
-------------------------------------------------------------------------*/
|
|
/* Macros to stringify the version number */
|
|
#define DRX_VERSIONSTRING( MAJOR, MINOR, PATCH ) \
|
|
DRX_VERSIONSTRING_HELP(MAJOR)"." \
|
|
DRX_VERSIONSTRING_HELP(MINOR)"." \
|
|
DRX_VERSIONSTRING_HELP(PATCH)
|
|
#define DRX_VERSIONSTRING_HELP( NUM ) #NUM
|
|
|
|
/**
|
|
* \brief Macro to create byte array elements from 16 bit integers.
|
|
* This macro is used to create byte arrays for block writes.
|
|
* Block writes speed up I2C traffic between host and demod.
|
|
* The macro takes care of the required byte order in a 16 bits word.
|
|
* x->lowbyte(x), highbyte(x)
|
|
*/
|
|
#define DRX_16TO8( x ) ((u8) (((u16)x) &0xFF)), \
|
|
((u8)((((u16)x)>>8)&0xFF))
|
|
|
|
/**
|
|
* \brief Macro to sign extend signed 9 bit value to signed 16 bit value
|
|
*/
|
|
#define DRX_S9TOS16(x) ((((u16)x)&0x100 )?((s16)((u16)(x)|0xFF00)):(x))
|
|
|
|
/**
|
|
* \brief Macro to sign extend signed 9 bit value to signed 16 bit value
|
|
*/
|
|
#define DRX_S24TODRXFREQ(x) ( ( ( (u32) x ) & 0x00800000UL ) ? \
|
|
( (s32) \
|
|
( ( (u32) x ) | 0xFF000000 ) ) : \
|
|
( (s32) x ) )
|
|
|
|
/**
|
|
* \brief Macro to convert 16 bit register value to a s32
|
|
*/
|
|
#define DRX_U16TODRXFREQ(x) ( ( x & 0x8000 ) ? \
|
|
( (s32) \
|
|
( ( (u32) x ) | 0xFFFF0000 ) ) : \
|
|
( (s32) x ) )
|
|
|
|
/*-------------------------------------------------------------------------
|
|
ENUM
|
|
-------------------------------------------------------------------------*/
|
|
|
|
/**
|
|
* \enum enum drx_standard
|
|
* \brief Modulation standards.
|
|
*/
|
|
enum drx_standard {
|
|
DRX_STANDARD_DVBT = 0, /**< Terrestrial DVB-T. */
|
|
DRX_STANDARD_8VSB, /**< Terrestrial 8VSB. */
|
|
DRX_STANDARD_NTSC, /**< Terrestrial\Cable analog NTSC. */
|
|
DRX_STANDARD_PAL_SECAM_BG,
|
|
/**< Terrestrial analog PAL/SECAM B/G */
|
|
DRX_STANDARD_PAL_SECAM_DK,
|
|
/**< Terrestrial analog PAL/SECAM D/K */
|
|
DRX_STANDARD_PAL_SECAM_I,
|
|
/**< Terrestrial analog PAL/SECAM I */
|
|
DRX_STANDARD_PAL_SECAM_L,
|
|
/**< Terrestrial analog PAL/SECAM L
|
|
with negative modulation */
|
|
DRX_STANDARD_PAL_SECAM_LP,
|
|
/**< Terrestrial analog PAL/SECAM L
|
|
with positive modulation */
|
|
DRX_STANDARD_ITU_A, /**< Cable ITU ANNEX A. */
|
|
DRX_STANDARD_ITU_B, /**< Cable ITU ANNEX B. */
|
|
DRX_STANDARD_ITU_C, /**< Cable ITU ANNEX C. */
|
|
DRX_STANDARD_ITU_D, /**< Cable ITU ANNEX D. */
|
|
DRX_STANDARD_FM, /**< Terrestrial\Cable FM radio */
|
|
DRX_STANDARD_DTMB, /**< Terrestrial DTMB standard (China)*/
|
|
DRX_STANDARD_UNKNOWN = DRX_UNKNOWN,
|
|
/**< Standard unknown. */
|
|
DRX_STANDARD_AUTO = DRX_AUTO
|
|
/**< Autodetect standard. */
|
|
};
|
|
|
|
/**
|
|
* \enum enum drx_standard
|
|
* \brief Modulation sub-standards.
|
|
*/
|
|
enum drx_substandard {
|
|
DRX_SUBSTANDARD_MAIN = 0, /**< Main subvariant of standard */
|
|
DRX_SUBSTANDARD_ATV_BG_SCANDINAVIA,
|
|
DRX_SUBSTANDARD_ATV_DK_POLAND,
|
|
DRX_SUBSTANDARD_ATV_DK_CHINA,
|
|
DRX_SUBSTANDARD_UNKNOWN = DRX_UNKNOWN,
|
|
/**< Sub-standard unknown. */
|
|
DRX_SUBSTANDARD_AUTO = DRX_AUTO
|
|
/**< Auto (default) sub-standard */
|
|
};
|
|
|
|
/**
|
|
* \enum enum drx_bandwidth
|
|
* \brief Channel bandwidth or channel spacing.
|
|
*/
|
|
enum drx_bandwidth {
|
|
DRX_BANDWIDTH_8MHZ = 0, /**< Bandwidth 8 MHz. */
|
|
DRX_BANDWIDTH_7MHZ, /**< Bandwidth 7 MHz. */
|
|
DRX_BANDWIDTH_6MHZ, /**< Bandwidth 6 MHz. */
|
|
DRX_BANDWIDTH_UNKNOWN = DRX_UNKNOWN,
|
|
/**< Bandwidth unknown. */
|
|
DRX_BANDWIDTH_AUTO = DRX_AUTO
|
|
/**< Auto Set Bandwidth */
|
|
};
|
|
|
|
/**
|
|
* \enum enum drx_mirror
|
|
* \brief Indicate if channel spectrum is mirrored or not.
|
|
*/
|
|
enum drx_mirror{
|
|
DRX_MIRROR_NO = 0, /**< Spectrum is not mirrored. */
|
|
DRX_MIRROR_YES, /**< Spectrum is mirrored. */
|
|
DRX_MIRROR_UNKNOWN = DRX_UNKNOWN,
|
|
/**< Unknown if spectrum is mirrored. */
|
|
DRX_MIRROR_AUTO = DRX_AUTO
|
|
/**< Autodetect if spectrum is mirrored. */
|
|
};
|
|
|
|
/**
|
|
* \enum enum drx_modulation
|
|
* \brief Constellation type of the channel.
|
|
*/
|
|
enum drx_modulation {
|
|
DRX_CONSTELLATION_BPSK = 0, /**< Modulation is BPSK. */
|
|
DRX_CONSTELLATION_QPSK, /**< Constellation is QPSK. */
|
|
DRX_CONSTELLATION_PSK8, /**< Constellation is PSK8. */
|
|
DRX_CONSTELLATION_QAM16, /**< Constellation is QAM16. */
|
|
DRX_CONSTELLATION_QAM32, /**< Constellation is QAM32. */
|
|
DRX_CONSTELLATION_QAM64, /**< Constellation is QAM64. */
|
|
DRX_CONSTELLATION_QAM128, /**< Constellation is QAM128. */
|
|
DRX_CONSTELLATION_QAM256, /**< Constellation is QAM256. */
|
|
DRX_CONSTELLATION_QAM512, /**< Constellation is QAM512. */
|
|
DRX_CONSTELLATION_QAM1024, /**< Constellation is QAM1024. */
|
|
DRX_CONSTELLATION_QPSK_NR, /**< Constellation is QPSK_NR */
|
|
DRX_CONSTELLATION_UNKNOWN = DRX_UNKNOWN,
|
|
/**< Constellation unknown. */
|
|
DRX_CONSTELLATION_AUTO = DRX_AUTO
|
|
/**< Autodetect constellation. */
|
|
};
|
|
|
|
/**
|
|
* \enum enum drx_hierarchy
|
|
* \brief Hierarchy of the channel.
|
|
*/
|
|
enum drx_hierarchy {
|
|
DRX_HIERARCHY_NONE = 0, /**< None hierarchical channel. */
|
|
DRX_HIERARCHY_ALPHA1, /**< Hierarchical channel, alpha=1. */
|
|
DRX_HIERARCHY_ALPHA2, /**< Hierarchical channel, alpha=2. */
|
|
DRX_HIERARCHY_ALPHA4, /**< Hierarchical channel, alpha=4. */
|
|
DRX_HIERARCHY_UNKNOWN = DRX_UNKNOWN,
|
|
/**< Hierarchy unknown. */
|
|
DRX_HIERARCHY_AUTO = DRX_AUTO
|
|
/**< Autodetect hierarchy. */
|
|
};
|
|
|
|
/**
|
|
* \enum enum drx_priority
|
|
* \brief Channel priority in case of hierarchical transmission.
|
|
*/
|
|
enum drx_priority {
|
|
DRX_PRIORITY_LOW = 0, /**< Low priority channel. */
|
|
DRX_PRIORITY_HIGH, /**< High priority channel. */
|
|
DRX_PRIORITY_UNKNOWN = DRX_UNKNOWN
|
|
/**< Priority unknown. */
|
|
};
|
|
|
|
/**
|
|
* \enum enum drx_coderate
|
|
* \brief Channel priority in case of hierarchical transmission.
|
|
*/
|
|
enum drx_coderate{
|
|
DRX_CODERATE_1DIV2 = 0, /**< Code rate 1/2nd. */
|
|
DRX_CODERATE_2DIV3, /**< Code rate 2/3nd. */
|
|
DRX_CODERATE_3DIV4, /**< Code rate 3/4nd. */
|
|
DRX_CODERATE_5DIV6, /**< Code rate 5/6nd. */
|
|
DRX_CODERATE_7DIV8, /**< Code rate 7/8nd. */
|
|
DRX_CODERATE_UNKNOWN = DRX_UNKNOWN,
|
|
/**< Code rate unknown. */
|
|
DRX_CODERATE_AUTO = DRX_AUTO
|
|
/**< Autodetect code rate. */
|
|
};
|
|
|
|
/**
|
|
* \enum enum drx_guard
|
|
* \brief Guard interval of a channel.
|
|
*/
|
|
enum drx_guard {
|
|
DRX_GUARD_1DIV32 = 0, /**< Guard interval 1/32nd. */
|
|
DRX_GUARD_1DIV16, /**< Guard interval 1/16th. */
|
|
DRX_GUARD_1DIV8, /**< Guard interval 1/8th. */
|
|
DRX_GUARD_1DIV4, /**< Guard interval 1/4th. */
|
|
DRX_GUARD_UNKNOWN = DRX_UNKNOWN,
|
|
/**< Guard interval unknown. */
|
|
DRX_GUARD_AUTO = DRX_AUTO
|
|
/**< Autodetect guard interval. */
|
|
};
|
|
|
|
/**
|
|
* \enum enum drx_fft_mode
|
|
* \brief FFT mode.
|
|
*/
|
|
enum drx_fft_mode {
|
|
DRX_FFTMODE_2K = 0, /**< 2K FFT mode. */
|
|
DRX_FFTMODE_4K, /**< 4K FFT mode. */
|
|
DRX_FFTMODE_8K, /**< 8K FFT mode. */
|
|
DRX_FFTMODE_UNKNOWN = DRX_UNKNOWN,
|
|
/**< FFT mode unknown. */
|
|
DRX_FFTMODE_AUTO = DRX_AUTO
|
|
/**< Autodetect FFT mode. */
|
|
};
|
|
|
|
/**
|
|
* \enum enum drx_classification
|
|
* \brief Channel classification.
|
|
*/
|
|
enum drx_classification {
|
|
DRX_CLASSIFICATION_GAUSS = 0, /**< Gaussion noise. */
|
|
DRX_CLASSIFICATION_HVY_GAUSS, /**< Heavy Gaussion noise. */
|
|
DRX_CLASSIFICATION_COCHANNEL, /**< Co-channel. */
|
|
DRX_CLASSIFICATION_STATIC, /**< Static echo. */
|
|
DRX_CLASSIFICATION_MOVING, /**< Moving echo. */
|
|
DRX_CLASSIFICATION_ZERODB, /**< Zero dB echo. */
|
|
DRX_CLASSIFICATION_UNKNOWN = DRX_UNKNOWN,
|
|
/**< Unknown classification */
|
|
DRX_CLASSIFICATION_AUTO = DRX_AUTO
|
|
/**< Autodetect classification. */
|
|
};
|
|
|
|
/**
|
|
* /enum enum drx_interleave_mode
|
|
* /brief Interleave modes
|
|
*/
|
|
enum drx_interleave_mode {
|
|
DRX_INTERLEAVEMODE_I128_J1 = 0,
|
|
DRX_INTERLEAVEMODE_I128_J1_V2,
|
|
DRX_INTERLEAVEMODE_I128_J2,
|
|
DRX_INTERLEAVEMODE_I64_J2,
|
|
DRX_INTERLEAVEMODE_I128_J3,
|
|
DRX_INTERLEAVEMODE_I32_J4,
|
|
DRX_INTERLEAVEMODE_I128_J4,
|
|
DRX_INTERLEAVEMODE_I16_J8,
|
|
DRX_INTERLEAVEMODE_I128_J5,
|
|
DRX_INTERLEAVEMODE_I8_J16,
|
|
DRX_INTERLEAVEMODE_I128_J6,
|
|
DRX_INTERLEAVEMODE_RESERVED_11,
|
|
DRX_INTERLEAVEMODE_I128_J7,
|
|
DRX_INTERLEAVEMODE_RESERVED_13,
|
|
DRX_INTERLEAVEMODE_I128_J8,
|
|
DRX_INTERLEAVEMODE_RESERVED_15,
|
|
DRX_INTERLEAVEMODE_I12_J17,
|
|
DRX_INTERLEAVEMODE_I5_J4,
|
|
DRX_INTERLEAVEMODE_B52_M240,
|
|
DRX_INTERLEAVEMODE_B52_M720,
|
|
DRX_INTERLEAVEMODE_B52_M48,
|
|
DRX_INTERLEAVEMODE_B52_M0,
|
|
DRX_INTERLEAVEMODE_UNKNOWN = DRX_UNKNOWN,
|
|
/**< Unknown interleave mode */
|
|
DRX_INTERLEAVEMODE_AUTO = DRX_AUTO
|
|
/**< Autodetect interleave mode */
|
|
};
|
|
|
|
/**
|
|
* \enum enum drx_carrier_mode
|
|
* \brief Channel Carrier Mode.
|
|
*/
|
|
enum drx_carrier_mode{
|
|
DRX_CARRIER_MULTI = 0, /**< Multi carrier mode */
|
|
DRX_CARRIER_SINGLE, /**< Single carrier mode */
|
|
DRX_CARRIER_UNKNOWN = DRX_UNKNOWN,
|
|
/**< Carrier mode unknown. */
|
|
DRX_CARRIER_AUTO = DRX_AUTO /**< Autodetect carrier mode */
|
|
};
|
|
|
|
/**
|
|
* \enum enum drx_frame_mode
|
|
* \brief Channel Frame Mode.
|
|
*/
|
|
enum drx_frame_mode{
|
|
DRX_FRAMEMODE_420 = 0, /**< 420 with variable PN */
|
|
DRX_FRAMEMODE_595, /**< 595 */
|
|
DRX_FRAMEMODE_945, /**< 945 with variable PN */
|
|
DRX_FRAMEMODE_420_FIXED_PN,
|
|
/**< 420 with fixed PN */
|
|
DRX_FRAMEMODE_945_FIXED_PN,
|
|
/**< 945 with fixed PN */
|
|
DRX_FRAMEMODE_UNKNOWN = DRX_UNKNOWN,
|
|
/**< Frame mode unknown. */
|
|
DRX_FRAMEMODE_AUTO = DRX_AUTO
|
|
/**< Autodetect frame mode */
|
|
};
|
|
|
|
/**
|
|
* \enum enum drx_tps_frame
|
|
* \brief Frame number in current super-frame.
|
|
*/
|
|
enum drx_tps_frame{
|
|
DRX_TPS_FRAME1 = 0, /**< TPS frame 1. */
|
|
DRX_TPS_FRAME2, /**< TPS frame 2. */
|
|
DRX_TPS_FRAME3, /**< TPS frame 3. */
|
|
DRX_TPS_FRAME4, /**< TPS frame 4. */
|
|
DRX_TPS_FRAME_UNKNOWN = DRX_UNKNOWN
|
|
/**< TPS frame unknown. */
|
|
};
|
|
|
|
/**
|
|
* \enum enum drx_ldpc
|
|
* \brief TPS LDPC .
|
|
*/
|
|
enum drx_ldpc{
|
|
DRX_LDPC_0_4 = 0, /**< LDPC 0.4 */
|
|
DRX_LDPC_0_6, /**< LDPC 0.6 */
|
|
DRX_LDPC_0_8, /**< LDPC 0.8 */
|
|
DRX_LDPC_UNKNOWN = DRX_UNKNOWN,
|
|
/**< LDPC unknown. */
|
|
DRX_LDPC_AUTO = DRX_AUTO /**< Autodetect LDPC */
|
|
};
|
|
|
|
/**
|
|
* \enum enum drx_pilot_mode
|
|
* \brief Pilot modes in DTMB.
|
|
*/
|
|
enum drx_pilot_mode{
|
|
DRX_PILOT_ON = 0, /**< Pilot On */
|
|
DRX_PILOT_OFF, /**< Pilot Off */
|
|
DRX_PILOT_UNKNOWN = DRX_UNKNOWN,
|
|
/**< Pilot unknown. */
|
|
DRX_PILOT_AUTO = DRX_AUTO /**< Autodetect Pilot */
|
|
};
|
|
|
|
#define DRX_CTRL_BASE ((u32)0)
|
|
|
|
#define DRX_CTRL_NOP ( DRX_CTRL_BASE + 0)/**< No Operation */
|
|
#define DRX_CTRL_PROBE_DEVICE ( DRX_CTRL_BASE + 1)/**< Probe device */
|
|
|
|
#define DRX_CTRL_LOAD_UCODE ( DRX_CTRL_BASE + 2)/**< Load microcode */
|
|
#define DRX_CTRL_VERIFY_UCODE ( DRX_CTRL_BASE + 3)/**< Verify microcode */
|
|
#define DRX_CTRL_SET_CHANNEL ( DRX_CTRL_BASE + 4)/**< Set channel */
|
|
#define DRX_CTRL_GET_CHANNEL ( DRX_CTRL_BASE + 5)/**< Get channel */
|
|
#define DRX_CTRL_LOCK_STATUS ( DRX_CTRL_BASE + 6)/**< Get lock status */
|
|
#define DRX_CTRL_SIG_QUALITY ( DRX_CTRL_BASE + 7)/**< Get signal quality */
|
|
#define DRX_CTRL_SIG_STRENGTH ( DRX_CTRL_BASE + 8)/**< Get signal strength*/
|
|
#define DRX_CTRL_RF_POWER ( DRX_CTRL_BASE + 9)/**< Get RF power */
|
|
#define DRX_CTRL_CONSTEL ( DRX_CTRL_BASE + 10)/**< Get constel point */
|
|
#define DRX_CTRL_SCAN_INIT ( DRX_CTRL_BASE + 11)/**< Initialize scan */
|
|
#define DRX_CTRL_SCAN_NEXT ( DRX_CTRL_BASE + 12)/**< Scan for next */
|
|
#define DRX_CTRL_SCAN_STOP ( DRX_CTRL_BASE + 13)/**< Stop scan */
|
|
#define DRX_CTRL_TPS_INFO ( DRX_CTRL_BASE + 14)/**< Get TPS info */
|
|
#define DRX_CTRL_SET_CFG ( DRX_CTRL_BASE + 15)/**< Set configuration */
|
|
#define DRX_CTRL_GET_CFG ( DRX_CTRL_BASE + 16)/**< Get configuration */
|
|
#define DRX_CTRL_VERSION ( DRX_CTRL_BASE + 17)/**< Get version info */
|
|
#define DRX_CTRL_I2C_BRIDGE ( DRX_CTRL_BASE + 18)/**< Open/close bridge */
|
|
#define DRX_CTRL_SET_STANDARD ( DRX_CTRL_BASE + 19)/**< Set demod std */
|
|
#define DRX_CTRL_GET_STANDARD ( DRX_CTRL_BASE + 20)/**< Get demod std */
|
|
#define DRX_CTRL_SET_OOB ( DRX_CTRL_BASE + 21)/**< Set OOB param */
|
|
#define DRX_CTRL_GET_OOB ( DRX_CTRL_BASE + 22)/**< Get OOB param */
|
|
#define DRX_CTRL_AUD_SET_STANDARD (DRX_CTRL_BASE + 23)/**< Set audio param */
|
|
#define DRX_CTRL_AUD_GET_STANDARD (DRX_CTRL_BASE + 24)/**< Get audio param */
|
|
#define DRX_CTRL_AUD_GET_STATUS ( DRX_CTRL_BASE + 25)/**< Read RDS */
|
|
#define DRX_CTRL_AUD_BEEP ( DRX_CTRL_BASE + 26)/**< Read RDS */
|
|
#define DRX_CTRL_I2C_READWRITE ( DRX_CTRL_BASE + 27)/**< Read/write I2C */
|
|
#define DRX_CTRL_PROGRAM_TUNER ( DRX_CTRL_BASE + 28)/**< Program tuner */
|
|
|
|
/* Professional */
|
|
#define DRX_CTRL_MB_CFG ( DRX_CTRL_BASE + 29) /**< */
|
|
#define DRX_CTRL_MB_READ ( DRX_CTRL_BASE + 30) /**< */
|
|
#define DRX_CTRL_MB_WRITE ( DRX_CTRL_BASE + 31) /**< */
|
|
#define DRX_CTRL_MB_CONSTEL ( DRX_CTRL_BASE + 32) /**< */
|
|
#define DRX_CTRL_MB_MER ( DRX_CTRL_BASE + 33) /**< */
|
|
|
|
/* Misc */
|
|
#define DRX_CTRL_UIO_CFG DRX_CTRL_SET_UIO_CFG /**< Configure UIO */
|
|
#define DRX_CTRL_SET_UIO_CFG ( DRX_CTRL_BASE + 34) /**< Configure UIO */
|
|
#define DRX_CTRL_GET_UIO_CFG ( DRX_CTRL_BASE + 35) /**< Configure UIO */
|
|
#define DRX_CTRL_UIO_READ ( DRX_CTRL_BASE + 36) /**< Read from UIO */
|
|
#define DRX_CTRL_UIO_WRITE ( DRX_CTRL_BASE + 37) /**< Write to UIO */
|
|
#define DRX_CTRL_READ_EVENTS ( DRX_CTRL_BASE + 38) /**< Read events */
|
|
#define DRX_CTRL_HDL_EVENTS ( DRX_CTRL_BASE + 39) /**< Handle events */
|
|
#define DRX_CTRL_POWER_MODE ( DRX_CTRL_BASE + 40) /**< Set power mode */
|
|
#define DRX_CTRL_LOAD_FILTER ( DRX_CTRL_BASE + 41) /**< Load chan. filter */
|
|
#define DRX_CTRL_VALIDATE_UCODE ( DRX_CTRL_BASE + 42) /**< Validate ucode */
|
|
#define DRX_CTRL_DUMP_REGISTERS ( DRX_CTRL_BASE + 43) /**< Dump registers */
|
|
|
|
#define DRX_CTRL_MAX ( DRX_CTRL_BASE + 44) /* never to be used */
|
|
|
|
/**
|
|
* \enum DRXUCodeAction_t
|
|
* \brief Used to indicate if firmware has to be uploaded or verified.
|
|
*/
|
|
|
|
typedef enum {
|
|
UCODE_UPLOAD,
|
|
/**< Upload the microcode image to device */
|
|
UCODE_VERIFY
|
|
/**< Compare microcode image with code on device */
|
|
} DRXUCodeAction_t, *pDRXUCodeAction_t;
|
|
|
|
/**
|
|
* \enum DRXLockStatus_t
|
|
* \brief Used to reflect current lock status of demodulator.
|
|
*
|
|
* The generic lock states have device dependent semantics.
|
|
*/
|
|
typedef enum {
|
|
DRX_NEVER_LOCK = 0,
|
|
/**< Device will never lock on this signal */
|
|
DRX_NOT_LOCKED,
|
|
/**< Device has no lock at all */
|
|
DRX_LOCK_STATE_1,
|
|
/**< Generic lock state */
|
|
DRX_LOCK_STATE_2,
|
|
/**< Generic lock state */
|
|
DRX_LOCK_STATE_3,
|
|
/**< Generic lock state */
|
|
DRX_LOCK_STATE_4,
|
|
/**< Generic lock state */
|
|
DRX_LOCK_STATE_5,
|
|
/**< Generic lock state */
|
|
DRX_LOCK_STATE_6,
|
|
/**< Generic lock state */
|
|
DRX_LOCK_STATE_7,
|
|
/**< Generic lock state */
|
|
DRX_LOCK_STATE_8,
|
|
/**< Generic lock state */
|
|
DRX_LOCK_STATE_9,
|
|
/**< Generic lock state */
|
|
DRX_LOCKED /**< Device is in lock */
|
|
} DRXLockStatus_t, *pDRXLockStatus_t;
|
|
|
|
/**
|
|
* \enum DRXUIO_t
|
|
* \brief Used to address a User IO (UIO).
|
|
*/
|
|
typedef enum {
|
|
DRX_UIO1,
|
|
DRX_UIO2,
|
|
DRX_UIO3,
|
|
DRX_UIO4,
|
|
DRX_UIO5,
|
|
DRX_UIO6,
|
|
DRX_UIO7,
|
|
DRX_UIO8,
|
|
DRX_UIO9,
|
|
DRX_UIO10,
|
|
DRX_UIO11,
|
|
DRX_UIO12,
|
|
DRX_UIO13,
|
|
DRX_UIO14,
|
|
DRX_UIO15,
|
|
DRX_UIO16,
|
|
DRX_UIO17,
|
|
DRX_UIO18,
|
|
DRX_UIO19,
|
|
DRX_UIO20,
|
|
DRX_UIO21,
|
|
DRX_UIO22,
|
|
DRX_UIO23,
|
|
DRX_UIO24,
|
|
DRX_UIO25,
|
|
DRX_UIO26,
|
|
DRX_UIO27,
|
|
DRX_UIO28,
|
|
DRX_UIO29,
|
|
DRX_UIO30,
|
|
DRX_UIO31,
|
|
DRX_UIO32,
|
|
DRX_UIO_MAX = DRX_UIO32
|
|
} DRXUIO_t, *pDRXUIO_t;
|
|
|
|
/**
|
|
* \enum DRXUIOMode_t
|
|
* \brief Used to configure the modus oprandi of a UIO.
|
|
*
|
|
* DRX_UIO_MODE_FIRMWARE is an old uio mode.
|
|
* It is replaced by the modes DRX_UIO_MODE_FIRMWARE0 .. DRX_UIO_MODE_FIRMWARE9.
|
|
* To be backward compatible DRX_UIO_MODE_FIRMWARE is equivalent to
|
|
* DRX_UIO_MODE_FIRMWARE0.
|
|
*/
|
|
typedef enum {
|
|
DRX_UIO_MODE_DISABLE = 0x01,
|
|
/**< not used, pin is configured as input */
|
|
DRX_UIO_MODE_READWRITE = 0x02,
|
|
/**< used for read/write by application */
|
|
DRX_UIO_MODE_FIRMWARE = 0x04,
|
|
/**< controlled by firmware, function 0 */
|
|
DRX_UIO_MODE_FIRMWARE0 = DRX_UIO_MODE_FIRMWARE,
|
|
/**< same as above */
|
|
DRX_UIO_MODE_FIRMWARE1 = 0x08,
|
|
/**< controlled by firmware, function 1 */
|
|
DRX_UIO_MODE_FIRMWARE2 = 0x10,
|
|
/**< controlled by firmware, function 2 */
|
|
DRX_UIO_MODE_FIRMWARE3 = 0x20,
|
|
/**< controlled by firmware, function 3 */
|
|
DRX_UIO_MODE_FIRMWARE4 = 0x40,
|
|
/**< controlled by firmware, function 4 */
|
|
DRX_UIO_MODE_FIRMWARE5 = 0x80
|
|
/**< controlled by firmware, function 5 */
|
|
} DRXUIOMode_t, *pDRXUIOMode_t;
|
|
|
|
/**
|
|
* \enum DRXOOBDownstreamStandard_t
|
|
* \brief Used to select OOB standard.
|
|
*
|
|
* Based on ANSI 55-1 and 55-2
|
|
*/
|
|
typedef enum {
|
|
DRX_OOB_MODE_A = 0,
|
|
/**< ANSI 55-1 */
|
|
DRX_OOB_MODE_B_GRADE_A,
|
|
/**< ANSI 55-2 A */
|
|
DRX_OOB_MODE_B_GRADE_B
|
|
/**< ANSI 55-2 B */
|
|
} DRXOOBDownstreamStandard_t, *pDRXOOBDownstreamStandard_t;
|
|
|
|
/*-------------------------------------------------------------------------
|
|
STRUCTS
|
|
-------------------------------------------------------------------------*/
|
|
|
|
/*============================================================================*/
|
|
/*============================================================================*/
|
|
/*== CTRL CFG related data structures ========================================*/
|
|
/*============================================================================*/
|
|
/*============================================================================*/
|
|
|
|
/**
|
|
* \enum DRXCfgType_t
|
|
* \brief Generic configuration function identifiers.
|
|
*/
|
|
typedef u32 DRXCfgType_t, *pDRXCfgType_t;
|
|
|
|
#ifndef DRX_CFG_BASE
|
|
#define DRX_CFG_BASE ((DRXCfgType_t)0)
|
|
#endif
|
|
|
|
#define DRX_CFG_MPEG_OUTPUT ( DRX_CFG_BASE + 0) /* MPEG TS output */
|
|
#define DRX_CFG_PKTERR ( DRX_CFG_BASE + 1) /* Packet Error */
|
|
#define DRX_CFG_SYMCLK_OFFS ( DRX_CFG_BASE + 2) /* Symbol Clk Offset */
|
|
#define DRX_CFG_SMA ( DRX_CFG_BASE + 3) /* Smart Antenna */
|
|
#define DRX_CFG_PINSAFE ( DRX_CFG_BASE + 4) /* Pin safe mode */
|
|
#define DRX_CFG_SUBSTANDARD ( DRX_CFG_BASE + 5) /* substandard */
|
|
#define DRX_CFG_AUD_VOLUME ( DRX_CFG_BASE + 6) /* volume */
|
|
#define DRX_CFG_AUD_RDS ( DRX_CFG_BASE + 7) /* rds */
|
|
#define DRX_CFG_AUD_AUTOSOUND ( DRX_CFG_BASE + 8) /* ASS & ASC */
|
|
#define DRX_CFG_AUD_ASS_THRES ( DRX_CFG_BASE + 9) /* ASS Thresholds */
|
|
#define DRX_CFG_AUD_DEVIATION ( DRX_CFG_BASE + 10) /* Deviation */
|
|
#define DRX_CFG_AUD_PRESCALE ( DRX_CFG_BASE + 11) /* Prescale */
|
|
#define DRX_CFG_AUD_MIXER ( DRX_CFG_BASE + 12) /* Mixer */
|
|
#define DRX_CFG_AUD_AVSYNC ( DRX_CFG_BASE + 13) /* AVSync */
|
|
#define DRX_CFG_AUD_CARRIER ( DRX_CFG_BASE + 14) /* Audio carriers */
|
|
#define DRX_CFG_I2S_OUTPUT ( DRX_CFG_BASE + 15) /* I2S output */
|
|
#define DRX_CFG_ATV_STANDARD ( DRX_CFG_BASE + 16) /* ATV standard */
|
|
#define DRX_CFG_SQI_SPEED ( DRX_CFG_BASE + 17) /* SQI speed */
|
|
#define DRX_CTRL_CFG_MAX ( DRX_CFG_BASE + 18) /* never to be used */
|
|
|
|
#define DRX_CFG_PINS_SAFE_MODE DRX_CFG_PINSAFE
|
|
/*============================================================================*/
|
|
/*============================================================================*/
|
|
/*== CTRL related data structures ============================================*/
|
|
/*============================================================================*/
|
|
/*============================================================================*/
|
|
|
|
/**
|
|
* \struct DRXUCodeInfo_t
|
|
* \brief Parameters for microcode upload and verfiy.
|
|
*
|
|
* Used by DRX_CTRL_LOAD_UCODE and DRX_CTRL_VERIFY_UCODE
|
|
*/
|
|
typedef struct {
|
|
u8 *mcData;
|
|
/**< Pointer to microcode image. */
|
|
u16 mcSize;
|
|
/**< Microcode image size. */
|
|
} DRXUCodeInfo_t, *pDRXUCodeInfo_t;
|
|
|
|
/**
|
|
* \struct DRXMcVersionRec_t
|
|
* \brief Microcode version record
|
|
* Version numbers are stored in BCD format, as usual:
|
|
* o major number = bits 31-20 (first three nibbles of MSW)
|
|
* o minor number = bits 19-16 (fourth nibble of MSW)
|
|
* o patch number = bits 15-0 (remaining nibbles in LSW)
|
|
*
|
|
* The device type indicates for which the device is meant. It is based on the
|
|
* JTAG ID, using everything except the bond ID and the metal fix.
|
|
*
|
|
* Special values:
|
|
* - mcDevType == 0 => any device allowed
|
|
* - mcBaseVersion == 0.0.0 => full microcode (mcVersion is the version)
|
|
* - mcBaseVersion != 0.0.0 => patch microcode, the base microcode version
|
|
* (mcVersion is the version)
|
|
*/
|
|
#define AUX_VER_RECORD 0x8000
|
|
|
|
typedef struct {
|
|
u16 auxType; /* type of aux data - 0x8000 for version record */
|
|
u32 mcDevType; /* device type, based on JTAG ID */
|
|
u32 mcVersion; /* version of microcode */
|
|
u32 mcBaseVersion; /* in case of patch: the original microcode version */
|
|
} DRXMcVersionRec_t, *pDRXMcVersionRec_t;
|
|
|
|
/*========================================*/
|
|
|
|
/**
|
|
* \struct DRXFilterInfo_t
|
|
* \brief Parameters for loading filter coefficients
|
|
*
|
|
* Used by DRX_CTRL_LOAD_FILTER
|
|
*/
|
|
typedef struct {
|
|
u8 *dataRe;
|
|
/**< pointer to coefficients for RE */
|
|
u8 *dataIm;
|
|
/**< pointer to coefficients for IM */
|
|
u16 sizeRe;
|
|
/**< size of coefficients for RE */
|
|
u16 sizeIm;
|
|
/**< size of coefficients for IM */
|
|
} DRXFilterInfo_t, *pDRXFilterInfo_t;
|
|
|
|
/*========================================*/
|
|
|
|
/**
|
|
* \struct DRXChannel_t
|
|
* \brief The set of parameters describing a single channel.
|
|
*
|
|
* Used by DRX_CTRL_SET_CHANNEL and DRX_CTRL_GET_CHANNEL.
|
|
* Only certain fields need to be used for a specfic standard.
|
|
*
|
|
*/
|
|
typedef struct {
|
|
s32 frequency;
|
|
/**< frequency in kHz */
|
|
enum drx_bandwidth bandwidth;
|
|
/**< bandwidth */
|
|
enum drx_mirror mirror; /**< mirrored or not on RF */
|
|
enum drx_modulation constellation;
|
|
/**< constellation */
|
|
enum drx_hierarchy hierarchy;
|
|
/**< hierarchy */
|
|
enum drx_priority priority; /**< priority */
|
|
enum drx_coderate coderate; /**< coderate */
|
|
enum drx_guard guard; /**< guard interval */
|
|
enum drx_fft_mode fftmode; /**< fftmode */
|
|
enum drx_classification classification;
|
|
/**< classification */
|
|
u32 symbolrate;
|
|
/**< symbolrate in symbols/sec */
|
|
enum drx_interleave_mode interleavemode;
|
|
/**< interleaveMode QAM */
|
|
enum drx_ldpc ldpc; /**< ldpc */
|
|
enum drx_carrier_mode carrier; /**< carrier */
|
|
enum drx_frame_mode framemode;
|
|
/**< frame mode */
|
|
enum drx_pilot_mode pilot; /**< pilot mode */
|
|
} DRXChannel_t, *pDRXChannel_t;
|
|
|
|
/*========================================*/
|
|
|
|
/**
|
|
* \struct DRXSigQuality_t
|
|
* Signal quality metrics.
|
|
*
|
|
* Used by DRX_CTRL_SIG_QUALITY.
|
|
*/
|
|
typedef struct {
|
|
u16 MER; /**< in steps of 0.1 dB */
|
|
u32 preViterbiBER;
|
|
/**< in steps of 1/scaleFactorBER */
|
|
u32 postViterbiBER;
|
|
/**< in steps of 1/scaleFactorBER */
|
|
u32 scaleFactorBER;
|
|
/**< scale factor for BER */
|
|
u16 packetError;
|
|
/**< number of packet errors */
|
|
u32 postReedSolomonBER;
|
|
/**< in steps of 1/scaleFactorBER */
|
|
u32 preLdpcBER;
|
|
/**< in steps of 1/scaleFactorBER */
|
|
u32 averIter;/**< in steps of 0.01 */
|
|
u16 indicator;
|
|
/**< indicative signal quality low=0..100=high */
|
|
} DRXSigQuality_t, *pDRXSigQuality_t;
|
|
|
|
typedef enum {
|
|
DRX_SQI_SPEED_FAST = 0,
|
|
DRX_SQI_SPEED_MEDIUM,
|
|
DRX_SQI_SPEED_SLOW,
|
|
DRX_SQI_SPEED_UNKNOWN = DRX_UNKNOWN
|
|
} DRXCfgSqiSpeed_t, *pDRXCfgSqiSpeed_t;
|
|
|
|
/*========================================*/
|
|
|
|
/**
|
|
* \struct DRXComplex_t
|
|
* A complex number.
|
|
*
|
|
* Used by DRX_CTRL_CONSTEL.
|
|
*/
|
|
typedef struct {
|
|
s16 im;
|
|
/**< Imaginary part. */
|
|
s16 re;
|
|
/**< Real part. */
|
|
} DRXComplex_t, *pDRXComplex_t;
|
|
|
|
/*========================================*/
|
|
|
|
/**
|
|
* \struct DRXFrequencyPlan_t
|
|
* Array element of a frequency plan.
|
|
*
|
|
* Used by DRX_CTRL_SCAN_INIT.
|
|
*/
|
|
typedef struct {
|
|
s32 first;
|
|
/**< First centre frequency in this band */
|
|
s32 last;
|
|
/**< Last centre frequency in this band */
|
|
s32 step;
|
|
/**< Stepping frequency in this band */
|
|
enum drx_bandwidth bandwidth;
|
|
/**< Bandwidth within this frequency band */
|
|
u16 chNumber;
|
|
/**< First channel number in this band, or first
|
|
index in chNames */
|
|
char **chNames;
|
|
/**< Optional list of channel names in this
|
|
band */
|
|
} DRXFrequencyPlan_t, *pDRXFrequencyPlan_t;
|
|
|
|
/*========================================*/
|
|
|
|
/**
|
|
* \struct DRXFrequencyPlanInfo_t
|
|
* Array element of a list of frequency plans.
|
|
*
|
|
* Used by frequency_plan.h
|
|
*/
|
|
typedef struct {
|
|
pDRXFrequencyPlan_t freqPlan;
|
|
int freqPlanSize;
|
|
char *freqPlanName;
|
|
} DRXFrequencyPlanInfo_t, *pDRXFrequencyPlanInfo_t;
|
|
|
|
/*========================================*/
|
|
|
|
/**
|
|
* /struct DRXScanDataQam_t
|
|
* QAM specific scanning variables
|
|
*/
|
|
typedef struct {
|
|
u32 *symbolrate; /**< list of symbolrates to scan */
|
|
u16 symbolrateSize; /**< size of symbolrate array */
|
|
enum drx_modulation *constellation;
|
|
/**< list of constellations */
|
|
u16 constellationSize; /**< size of constellation array */
|
|
u16 ifAgcThreshold; /**< thresholf for IF-AGC based
|
|
scanning filter */
|
|
} DRXScanDataQam_t, *pDRXScanDataQam_t;
|
|
|
|
/*========================================*/
|
|
|
|
/**
|
|
* /struct DRXScanDataAtv_t
|
|
* ATV specific scanning variables
|
|
*/
|
|
typedef struct {
|
|
s16 svrThreshold;
|
|
/**< threshold of Sound/Video ratio in 0.1dB steps */
|
|
} DRXScanDataAtv_t, *pDRXScanDataAtv_t;
|
|
|
|
/*========================================*/
|
|
|
|
/**
|
|
* \struct DRXScanParam_t
|
|
* Parameters for channel scan.
|
|
*
|
|
* Used by DRX_CTRL_SCAN_INIT.
|
|
*/
|
|
typedef struct {
|
|
pDRXFrequencyPlan_t frequencyPlan;
|
|
/**< Frequency plan (array)*/
|
|
u16 frequencyPlanSize; /**< Number of bands */
|
|
u32 numTries; /**< Max channels tried */
|
|
s32 skip; /**< Minimum frequency step to take
|
|
after a channel is found */
|
|
void *extParams; /**< Standard specific params */
|
|
} DRXScanParam_t, *pDRXScanParam_t;
|
|
|
|
/*========================================*/
|
|
|
|
/**
|
|
* \brief Scan commands.
|
|
* Used by scanning algorithms.
|
|
*/
|
|
typedef enum {
|
|
DRX_SCAN_COMMAND_INIT = 0,/**< Initialize scanning */
|
|
DRX_SCAN_COMMAND_NEXT, /**< Next scan */
|
|
DRX_SCAN_COMMAND_STOP /**< Stop scanning */
|
|
} DRXScanCommand_t, *pDRXScanCommand_t;
|
|
|
|
/*========================================*/
|
|
|
|
/**
|
|
* \brief Inner scan function prototype.
|
|
*/
|
|
typedef int(*DRXScanFunc_t) (void *scanContext,
|
|
DRXScanCommand_t scanCommand,
|
|
pDRXChannel_t scanChannel,
|
|
bool * getNextChannel);
|
|
|
|
/*========================================*/
|
|
|
|
/**
|
|
* \struct DRXTPSInfo_t
|
|
* TPS information, DVB-T specific.
|
|
*
|
|
* Used by DRX_CTRL_TPS_INFO.
|
|
*/
|
|
typedef struct {
|
|
enum drx_fft_mode fftmode; /**< Fft mode */
|
|
enum drx_guard guard; /**< Guard interval */
|
|
enum drx_modulation constellation;
|
|
/**< Constellation */
|
|
enum drx_hierarchy hierarchy;
|
|
/**< Hierarchy */
|
|
enum drx_coderate highCoderate;
|
|
/**< High code rate */
|
|
enum drx_coderate lowCoderate;
|
|
/**< Low cod rate */
|
|
enum drx_tps_frame frame; /**< Tps frame */
|
|
u8 length; /**< Length */
|
|
u16 cellId; /**< Cell id */
|
|
} DRXTPSInfo_t, *pDRXTPSInfo_t;
|
|
|
|
/*========================================*/
|
|
|
|
/**
|
|
* \brief Power mode of device.
|
|
*
|
|
* Used by DRX_CTRL_SET_POWER_MODE.
|
|
*/
|
|
typedef enum {
|
|
DRX_POWER_UP = 0,
|
|
/**< Generic , Power Up Mode */
|
|
DRX_POWER_MODE_1,
|
|
/**< Device specific , Power Up Mode */
|
|
DRX_POWER_MODE_2,
|
|
/**< Device specific , Power Up Mode */
|
|
DRX_POWER_MODE_3,
|
|
/**< Device specific , Power Up Mode */
|
|
DRX_POWER_MODE_4,
|
|
/**< Device specific , Power Up Mode */
|
|
DRX_POWER_MODE_5,
|
|
/**< Device specific , Power Up Mode */
|
|
DRX_POWER_MODE_6,
|
|
/**< Device specific , Power Up Mode */
|
|
DRX_POWER_MODE_7,
|
|
/**< Device specific , Power Up Mode */
|
|
DRX_POWER_MODE_8,
|
|
/**< Device specific , Power Up Mode */
|
|
|
|
DRX_POWER_MODE_9,
|
|
/**< Device specific , Power Down Mode */
|
|
DRX_POWER_MODE_10,
|
|
/**< Device specific , Power Down Mode */
|
|
DRX_POWER_MODE_11,
|
|
/**< Device specific , Power Down Mode */
|
|
DRX_POWER_MODE_12,
|
|
/**< Device specific , Power Down Mode */
|
|
DRX_POWER_MODE_13,
|
|
/**< Device specific , Power Down Mode */
|
|
DRX_POWER_MODE_14,
|
|
/**< Device specific , Power Down Mode */
|
|
DRX_POWER_MODE_15,
|
|
/**< Device specific , Power Down Mode */
|
|
DRX_POWER_MODE_16,
|
|
/**< Device specific , Power Down Mode */
|
|
DRX_POWER_DOWN = 255
|
|
/**< Generic , Power Down Mode */
|
|
} DRXPowerMode_t, *pDRXPowerMode_t;
|
|
|
|
/*========================================*/
|
|
|
|
/**
|
|
* \enum DRXModule_t
|
|
* \brief Software module identification.
|
|
*
|
|
* Used by DRX_CTRL_VERSION.
|
|
*/
|
|
typedef enum {
|
|
DRX_MODULE_DEVICE,
|
|
DRX_MODULE_MICROCODE,
|
|
DRX_MODULE_DRIVERCORE,
|
|
DRX_MODULE_DEVICEDRIVER,
|
|
DRX_MODULE_DAP,
|
|
DRX_MODULE_BSP_I2C,
|
|
DRX_MODULE_BSP_TUNER,
|
|
DRX_MODULE_BSP_HOST,
|
|
DRX_MODULE_UNKNOWN
|
|
} DRXModule_t, *pDRXModule_t;
|
|
|
|
/**
|
|
* \enum DRXVersion_t
|
|
* \brief Version information of one software module.
|
|
*
|
|
* Used by DRX_CTRL_VERSION.
|
|
*/
|
|
typedef struct {
|
|
DRXModule_t moduleType;
|
|
/**< Type identifier of the module */
|
|
char *moduleName;
|
|
/**< Name or description of module */
|
|
u16 vMajor; /**< Major version number */
|
|
u16 vMinor; /**< Minor version number */
|
|
u16 vPatch; /**< Patch version number */
|
|
char *vString; /**< Version as text string */
|
|
} DRXVersion_t, *pDRXVersion_t;
|
|
|
|
/**
|
|
* \enum DRXVersionList_t
|
|
* \brief List element of NULL terminated, linked list for version information.
|
|
*
|
|
* Used by DRX_CTRL_VERSION.
|
|
*/
|
|
typedef struct DRXVersionList_s {
|
|
pDRXVersion_t version;/**< Version information */
|
|
struct DRXVersionList_s *next;
|
|
/**< Next list element */
|
|
} DRXVersionList_t, *pDRXVersionList_t;
|
|
|
|
/*========================================*/
|
|
|
|
/**
|
|
* \brief Parameters needed to confiugure a UIO.
|
|
*
|
|
* Used by DRX_CTRL_UIO_CFG.
|
|
*/
|
|
typedef struct {
|
|
DRXUIO_t uio;
|
|
/**< UIO identifier */
|
|
DRXUIOMode_t mode;
|
|
/**< UIO operational mode */
|
|
} DRXUIOCfg_t, *pDRXUIOCfg_t;
|
|
|
|
/*========================================*/
|
|
|
|
/**
|
|
* \brief Parameters needed to read from or write to a UIO.
|
|
*
|
|
* Used by DRX_CTRL_UIO_READ and DRX_CTRL_UIO_WRITE.
|
|
*/
|
|
typedef struct {
|
|
DRXUIO_t uio;
|
|
/**< UIO identifier */
|
|
bool value;
|
|
/**< UIO value (true=1, false=0) */
|
|
} DRXUIOData_t, *pDRXUIOData_t;
|
|
|
|
/*========================================*/
|
|
|
|
/**
|
|
* \brief Parameters needed to configure OOB.
|
|
*
|
|
* Used by DRX_CTRL_SET_OOB.
|
|
*/
|
|
typedef struct {
|
|
s32 frequency; /**< Frequency in kHz */
|
|
DRXOOBDownstreamStandard_t standard;
|
|
/**< OOB standard */
|
|
bool spectrumInverted; /**< If true, then spectrum
|
|
is inverted */
|
|
} DRXOOB_t, *pDRXOOB_t;
|
|
|
|
/*========================================*/
|
|
|
|
/**
|
|
* \brief Metrics from OOB.
|
|
*
|
|
* Used by DRX_CTRL_GET_OOB.
|
|
*/
|
|
typedef struct {
|
|
s32 frequency; /**< Frequency in Khz */
|
|
DRXLockStatus_t lock; /**< Lock status */
|
|
u32 mer; /**< MER */
|
|
s32 symbolRateOffset; /**< Symbolrate offset in ppm */
|
|
} DRXOOBStatus_t, *pDRXOOBStatus_t;
|
|
|
|
/*========================================*/
|
|
|
|
/**
|
|
* \brief Device dependent configuration data.
|
|
*
|
|
* Used by DRX_CTRL_SET_CFG and DRX_CTRL_GET_CFG.
|
|
* A sort of nested DRX_Ctrl() functionality for device specific controls.
|
|
*/
|
|
typedef struct {
|
|
DRXCfgType_t cfgType;
|
|
/**< Function identifier */
|
|
void *cfgData;
|
|
/**< Function data */
|
|
} DRXCfg_t, *pDRXCfg_t;
|
|
|
|
/*========================================*/
|
|
|
|
/**
|
|
* /struct DRXMpegStartWidth_t
|
|
* MStart width [nr MCLK cycles] for serial MPEG output.
|
|
*/
|
|
|
|
typedef enum {
|
|
DRX_MPEG_STR_WIDTH_1,
|
|
DRX_MPEG_STR_WIDTH_8
|
|
} DRXMPEGStrWidth_t, *pDRXMPEGStrWidth_t;
|
|
|
|
/* CTRL CFG MPEG ouput */
|
|
/**
|
|
* \struct DRXCfgMPEGOutput_t
|
|
* \brief Configuartion parameters for MPEG output control.
|
|
*
|
|
* Used by DRX_CFG_MPEG_OUTPUT, in combination with DRX_CTRL_SET_CFG and
|
|
* DRX_CTRL_GET_CFG.
|
|
*/
|
|
|
|
typedef struct {
|
|
bool enableMPEGOutput;/**< If true, enable MPEG output */
|
|
bool insertRSByte; /**< If true, insert RS byte */
|
|
bool enableParallel; /**< If true, parallel out otherwise
|
|
serial */
|
|
bool invertDATA; /**< If true, invert DATA signals */
|
|
bool invertERR; /**< If true, invert ERR signal */
|
|
bool invertSTR; /**< If true, invert STR signals */
|
|
bool invertVAL; /**< If true, invert VAL signals */
|
|
bool invertCLK; /**< If true, invert CLK signals */
|
|
bool staticCLK; /**< If true, static MPEG clockrate
|
|
will be used, otherwise clockrate
|
|
will adapt to the bitrate of the
|
|
TS */
|
|
u32 bitrate; /**< Maximum bitrate in b/s in case
|
|
static clockrate is selected */
|
|
DRXMPEGStrWidth_t widthSTR;
|
|
/**< MPEG start width */
|
|
} DRXCfgMPEGOutput_t, *pDRXCfgMPEGOutput_t;
|
|
|
|
/* CTRL CFG SMA */
|
|
/**
|
|
* /struct DRXCfgSMAIO_t
|
|
* smart antenna i/o.
|
|
*/
|
|
typedef enum DRXCfgSMAIO_t {
|
|
DRX_SMA_OUTPUT = 0,
|
|
DRX_SMA_INPUT
|
|
} DRXCfgSMAIO_t, *pDRXCfgSMAIO_t;
|
|
|
|
/**
|
|
* /struct DRXCfgSMA_t
|
|
* Set smart antenna.
|
|
*/
|
|
typedef struct {
|
|
DRXCfgSMAIO_t io;
|
|
u16 ctrlData;
|
|
bool smartAntInverted;
|
|
} DRXCfgSMA_t, *pDRXCfgSMA_t;
|
|
|
|
/*========================================*/
|
|
|
|
/**
|
|
* \struct DRXI2CData_t
|
|
* \brief Data for I2C via 2nd or 3rd or etc I2C port.
|
|
*
|
|
* Used by DRX_CTRL_I2C_READWRITE.
|
|
* If portNr is equal to primairy portNr BSPI2C will be used.
|
|
*
|
|
*/
|
|
typedef struct {
|
|
u16 portNr; /**< I2C port number */
|
|
struct i2c_device_addr *wDevAddr;
|
|
/**< Write device address */
|
|
u16 wCount; /**< Size of write data in bytes */
|
|
u8 *wData; /**< Pointer to write data */
|
|
struct i2c_device_addr *rDevAddr;
|
|
/**< Read device address */
|
|
u16 rCount; /**< Size of data to read in bytes */
|
|
u8 *rData; /**< Pointer to read buffer */
|
|
} DRXI2CData_t, *pDRXI2CData_t;
|
|
|
|
/*========================================*/
|
|
|
|
/**
|
|
* \enum DRXAudStandard_t
|
|
* \brief Audio standard identifier.
|
|
*
|
|
* Used by DRX_CTRL_SET_AUD.
|
|
*/
|
|
typedef enum {
|
|
DRX_AUD_STANDARD_BTSC, /**< set BTSC standard (USA) */
|
|
DRX_AUD_STANDARD_A2, /**< set A2-Korea FM Stereo */
|
|
DRX_AUD_STANDARD_EIAJ, /**< set to Japanese FM Stereo */
|
|
DRX_AUD_STANDARD_FM_STEREO,/**< set to FM-Stereo Radio */
|
|
DRX_AUD_STANDARD_M_MONO, /**< for 4.5 MHz mono detected */
|
|
DRX_AUD_STANDARD_D_K_MONO, /**< for 6.5 MHz mono detected */
|
|
DRX_AUD_STANDARD_BG_FM, /**< set BG_FM standard */
|
|
DRX_AUD_STANDARD_D_K1, /**< set D_K1 standard */
|
|
DRX_AUD_STANDARD_D_K2, /**< set D_K2 standard */
|
|
DRX_AUD_STANDARD_D_K3, /**< set D_K3 standard */
|
|
DRX_AUD_STANDARD_BG_NICAM_FM,
|
|
/**< set BG_NICAM_FM standard */
|
|
DRX_AUD_STANDARD_L_NICAM_AM,
|
|
/**< set L_NICAM_AM standard */
|
|
DRX_AUD_STANDARD_I_NICAM_FM,
|
|
/**< set I_NICAM_FM standard */
|
|
DRX_AUD_STANDARD_D_K_NICAM_FM,
|
|
/**< set D_K_NICAM_FM standard */
|
|
DRX_AUD_STANDARD_NOT_READY,/**< used to detect audio standard */
|
|
DRX_AUD_STANDARD_AUTO = DRX_AUTO,
|
|
/**< Automatic Standard Detection */
|
|
DRX_AUD_STANDARD_UNKNOWN = DRX_UNKNOWN
|
|
/**< used as auto and for readback */
|
|
} DRXAudStandard_t, *pDRXAudStandard_t;
|
|
|
|
/* CTRL_AUD_GET_STATUS - DRXAudStatus_t */
|
|
/**
|
|
* \enum DRXAudNICAMStatus_t
|
|
* \brief Status of NICAM carrier.
|
|
*/
|
|
typedef enum {
|
|
DRX_AUD_NICAM_DETECTED = 0,
|
|
/**< NICAM carrier detected */
|
|
DRX_AUD_NICAM_NOT_DETECTED,
|
|
/**< NICAM carrier not detected */
|
|
DRX_AUD_NICAM_BAD /**< NICAM carrier bad quality */
|
|
} DRXAudNICAMStatus_t, *pDRXAudNICAMStatus_t;
|
|
|
|
/**
|
|
* \struct DRXAudStatus_t
|
|
* \brief Audio status characteristics.
|
|
*/
|
|
typedef struct {
|
|
bool stereo; /**< stereo detection */
|
|
bool carrierA; /**< carrier A detected */
|
|
bool carrierB; /**< carrier B detected */
|
|
bool sap; /**< sap / bilingual detection */
|
|
bool rds; /**< RDS data array present */
|
|
DRXAudNICAMStatus_t nicamStatus;
|
|
/**< status of NICAM carrier */
|
|
s8 fmIdent; /**< FM Identification value */
|
|
} DRXAudStatus_t, *pDRXAudStatus_t;
|
|
|
|
/* CTRL_AUD_READ_RDS - DRXRDSdata_t */
|
|
|
|
/**
|
|
* \struct DRXRDSdata_t
|
|
* \brief Raw RDS data array.
|
|
*/
|
|
typedef struct {
|
|
bool valid; /**< RDS data validation */
|
|
u16 data[18]; /**< data from one RDS data array */
|
|
} DRXCfgAudRDS_t, *pDRXCfgAudRDS_t;
|
|
|
|
/* DRX_CFG_AUD_VOLUME - DRXCfgAudVolume_t - set/get */
|
|
/**
|
|
* \enum DRXAudAVCDecayTime_t
|
|
* \brief Automatic volume control configuration.
|
|
*/
|
|
typedef enum {
|
|
DRX_AUD_AVC_OFF, /**< Automatic volume control off */
|
|
DRX_AUD_AVC_DECAYTIME_8S, /**< level volume in 8 seconds */
|
|
DRX_AUD_AVC_DECAYTIME_4S, /**< level volume in 4 seconds */
|
|
DRX_AUD_AVC_DECAYTIME_2S, /**< level volume in 2 seconds */
|
|
DRX_AUD_AVC_DECAYTIME_20MS/**< level volume in 20 millisec */
|
|
} DRXAudAVCMode_t, *pDRXAudAVCMode_t;
|
|
|
|
/**
|
|
* /enum DRXAudMaxAVCGain_t
|
|
* /brief Automatic volume control max gain in audio baseband.
|
|
*/
|
|
typedef enum {
|
|
DRX_AUD_AVC_MAX_GAIN_0DB, /**< maximum AVC gain 0 dB */
|
|
DRX_AUD_AVC_MAX_GAIN_6DB, /**< maximum AVC gain 6 dB */
|
|
DRX_AUD_AVC_MAX_GAIN_12DB /**< maximum AVC gain 12 dB */
|
|
} DRXAudAVCMaxGain_t, *pDRXAudAVCMaxGain_t;
|
|
|
|
/**
|
|
* /enum DRXAudMaxAVCAtten_t
|
|
* /brief Automatic volume control max attenuation in audio baseband.
|
|
*/
|
|
typedef enum {
|
|
DRX_AUD_AVC_MAX_ATTEN_12DB,
|
|
/**< maximum AVC attenuation 12 dB */
|
|
DRX_AUD_AVC_MAX_ATTEN_18DB,
|
|
/**< maximum AVC attenuation 18 dB */
|
|
DRX_AUD_AVC_MAX_ATTEN_24DB/**< maximum AVC attenuation 24 dB */
|
|
} DRXAudAVCMaxAtten_t, *pDRXAudAVCMaxAtten_t;
|
|
/**
|
|
* \struct DRXCfgAudVolume_t
|
|
* \brief Audio volume configuration.
|
|
*/
|
|
typedef struct {
|
|
bool mute; /**< mute overrides volume setting */
|
|
s16 volume; /**< volume, range -114 to 12 dB */
|
|
DRXAudAVCMode_t avcMode; /**< AVC auto volume control mode */
|
|
u16 avcRefLevel; /**< AVC reference level */
|
|
DRXAudAVCMaxGain_t avcMaxGain;
|
|
/**< AVC max gain selection */
|
|
DRXAudAVCMaxAtten_t avcMaxAtten;
|
|
/**< AVC max attenuation selection */
|
|
s16 strengthLeft; /**< quasi-peak, left speaker */
|
|
s16 strengthRight; /**< quasi-peak, right speaker */
|
|
} DRXCfgAudVolume_t, *pDRXCfgAudVolume_t;
|
|
|
|
/* DRX_CFG_I2S_OUTPUT - DRXCfgI2SOutput_t - set/get */
|
|
/**
|
|
* \enum DRXI2SMode_t
|
|
* \brief I2S output mode.
|
|
*/
|
|
typedef enum {
|
|
DRX_I2S_MODE_MASTER, /**< I2S is in master mode */
|
|
DRX_I2S_MODE_SLAVE /**< I2S is in slave mode */
|
|
} DRXI2SMode_t, *pDRXI2SMode_t;
|
|
|
|
/**
|
|
* \enum DRXI2SWordLength_t
|
|
* \brief Width of I2S data.
|
|
*/
|
|
typedef enum {
|
|
DRX_I2S_WORDLENGTH_32 = 0,/**< I2S data is 32 bit wide */
|
|
DRX_I2S_WORDLENGTH_16 = 1 /**< I2S data is 16 bit wide */
|
|
} DRXI2SWordLength_t, *pDRXI2SWordLength_t;
|
|
|
|
/**
|
|
* \enum DRXI2SFormat_t
|
|
* \brief Data wordstrobe alignment for I2S.
|
|
*/
|
|
typedef enum {
|
|
DRX_I2S_FORMAT_WS_WITH_DATA,
|
|
/**< I2S data and wordstrobe are aligned */
|
|
DRX_I2S_FORMAT_WS_ADVANCED
|
|
/**< I2S data one cycle after wordstrobe */
|
|
} DRXI2SFormat_t, *pDRXI2SFormat_t;
|
|
|
|
/**
|
|
* \enum DRXI2SPolarity_t
|
|
* \brief Polarity of I2S data.
|
|
*/
|
|
typedef enum {
|
|
DRX_I2S_POLARITY_RIGHT,/**< wordstrobe - right high, left low */
|
|
DRX_I2S_POLARITY_LEFT /**< wordstrobe - right low, left high */
|
|
} DRXI2SPolarity_t, *pDRXI2SPolarity_t;
|
|
|
|
/**
|
|
* \struct DRXCfgI2SOutput_t
|
|
* \brief I2S output configuration.
|
|
*/
|
|
typedef struct {
|
|
bool outputEnable; /**< I2S output enable */
|
|
u32 frequency; /**< range from 8000-48000 Hz */
|
|
DRXI2SMode_t mode; /**< I2S mode, master or slave */
|
|
DRXI2SWordLength_t wordLength;
|
|
/**< I2S wordlength, 16 or 32 bits */
|
|
DRXI2SPolarity_t polarity;/**< I2S wordstrobe polarity */
|
|
DRXI2SFormat_t format; /**< I2S wordstrobe delay to data */
|
|
} DRXCfgI2SOutput_t, *pDRXCfgI2SOutput_t;
|
|
|
|
/* ------------------------------expert interface-----------------------------*/
|
|
/**
|
|
* /enum DRXAudFMDeemphasis_t
|
|
* setting for FM-Deemphasis in audio demodulator.
|
|
*
|
|
*/
|
|
typedef enum {
|
|
DRX_AUD_FM_DEEMPH_50US,
|
|
DRX_AUD_FM_DEEMPH_75US,
|
|
DRX_AUD_FM_DEEMPH_OFF
|
|
} DRXAudFMDeemphasis_t, *pDRXAudFMDeemphasis_t;
|
|
|
|
/**
|
|
* /enum DRXAudDeviation_t
|
|
* setting for deviation mode in audio demodulator.
|
|
*
|
|
*/
|
|
typedef enum {
|
|
DRX_AUD_DEVIATION_NORMAL,
|
|
DRX_AUD_DEVIATION_HIGH
|
|
} DRXCfgAudDeviation_t, *pDRXCfgAudDeviation_t;
|
|
|
|
/**
|
|
* /enum DRXNoCarrierOption_t
|
|
* setting for carrier, mute/noise.
|
|
*
|
|
*/
|
|
typedef enum {
|
|
DRX_NO_CARRIER_MUTE,
|
|
DRX_NO_CARRIER_NOISE
|
|
} DRXNoCarrierOption_t, *pDRXNoCarrierOption_t;
|
|
|
|
/**
|
|
* \enum DRXAudAutoSound_t
|
|
* \brief Automatic Sound
|
|
*/
|
|
typedef enum {
|
|
DRX_AUD_AUTO_SOUND_OFF = 0,
|
|
DRX_AUD_AUTO_SOUND_SELECT_ON_CHANGE_ON,
|
|
DRX_AUD_AUTO_SOUND_SELECT_ON_CHANGE_OFF
|
|
} DRXCfgAudAutoSound_t, *pDRXCfgAudAutoSound_t;
|
|
|
|
/**
|
|
* \enum DRXAudASSThres_t
|
|
* \brief Automatic Sound Select Thresholds
|
|
*/
|
|
typedef struct {
|
|
u16 a2; /* A2 Threshold for ASS configuration */
|
|
u16 btsc; /* BTSC Threshold for ASS configuration */
|
|
u16 nicam; /* Nicam Threshold for ASS configuration */
|
|
} DRXCfgAudASSThres_t, *pDRXCfgAudASSThres_t;
|
|
|
|
/**
|
|
* \struct DRXAudCarrier_t
|
|
* \brief Carrier detection related parameters
|
|
*/
|
|
typedef struct {
|
|
u16 thres; /* carrier detetcion threshold for primary carrier (A) */
|
|
DRXNoCarrierOption_t opt; /* Mute or noise at no carrier detection (A) */
|
|
s32 shift; /* DC level of incoming signal (A) */
|
|
s32 dco; /* frequency adjustment (A) */
|
|
} DRXAudCarrier_t, *pDRXCfgAudCarrier_t;
|
|
|
|
/**
|
|
* \struct DRXCfgAudCarriers_t
|
|
* \brief combining carrier A & B to one struct
|
|
*/
|
|
typedef struct {
|
|
DRXAudCarrier_t a;
|
|
DRXAudCarrier_t b;
|
|
} DRXCfgAudCarriers_t, *pDRXCfgAudCarriers_t;
|
|
|
|
/**
|
|
* /enum DRXAudI2SSrc_t
|
|
* Selection of audio source
|
|
*/
|
|
typedef enum {
|
|
DRX_AUD_SRC_MONO,
|
|
DRX_AUD_SRC_STEREO_OR_AB,
|
|
DRX_AUD_SRC_STEREO_OR_A,
|
|
DRX_AUD_SRC_STEREO_OR_B
|
|
} DRXAudI2SSrc_t, *pDRXAudI2SSrc_t;
|
|
|
|
/**
|
|
* \enum DRXAudI2SMatrix_t
|
|
* \brief Used for selecting I2S output.
|
|
*/
|
|
typedef enum {
|
|
DRX_AUD_I2S_MATRIX_A_MONO,
|
|
/**< A sound only, stereo or mono */
|
|
DRX_AUD_I2S_MATRIX_B_MONO,
|
|
/**< B sound only, stereo or mono */
|
|
DRX_AUD_I2S_MATRIX_STEREO,
|
|
/**< A+B sound, transparant */
|
|
DRX_AUD_I2S_MATRIX_MONO /**< A+B mixed to mono sum, (L+R)/2 */
|
|
} DRXAudI2SMatrix_t, *pDRXAudI2SMatrix_t;
|
|
|
|
/**
|
|
* /enum DRXAudFMMatrix_t
|
|
* setting for FM-Matrix in audio demodulator.
|
|
*
|
|
*/
|
|
typedef enum {
|
|
DRX_AUD_FM_MATRIX_NO_MATRIX,
|
|
DRX_AUD_FM_MATRIX_GERMAN,
|
|
DRX_AUD_FM_MATRIX_KOREAN,
|
|
DRX_AUD_FM_MATRIX_SOUND_A,
|
|
DRX_AUD_FM_MATRIX_SOUND_B
|
|
} DRXAudFMMatrix_t, *pDRXAudFMMatrix_t;
|
|
|
|
/**
|
|
* \struct DRXAudMatrices_t
|
|
* \brief Mixer settings
|
|
*/
|
|
typedef struct {
|
|
DRXAudI2SSrc_t sourceI2S;
|
|
DRXAudI2SMatrix_t matrixI2S;
|
|
DRXAudFMMatrix_t matrixFm;
|
|
} DRXCfgAudMixer_t, *pDRXCfgAudMixer_t;
|
|
|
|
/**
|
|
* \enum DRXI2SVidSync_t
|
|
* \brief Audio/video synchronization, interacts with I2S mode.
|
|
* AUTO_1 and AUTO_2 are for automatic video standard detection with preference
|
|
* for NTSC or Monochrome, because the frequencies are too close (59.94 & 60 Hz)
|
|
*/
|
|
typedef enum {
|
|
DRX_AUD_AVSYNC_OFF,/**< audio/video synchronization is off */
|
|
DRX_AUD_AVSYNC_NTSC,
|
|
/**< it is an NTSC system */
|
|
DRX_AUD_AVSYNC_MONOCHROME,
|
|
/**< it is a MONOCHROME system */
|
|
DRX_AUD_AVSYNC_PAL_SECAM
|
|
/**< it is a PAL/SECAM system */
|
|
} DRXCfgAudAVSync_t, *pDRXCfgAudAVSync_t;
|
|
|
|
/**
|
|
* \struct DRXCfgAudPrescale_t
|
|
* \brief Prescalers
|
|
*/
|
|
typedef struct {
|
|
u16 fmDeviation;
|
|
s16 nicamGain;
|
|
} DRXCfgAudPrescale_t, *pDRXCfgAudPrescale_t;
|
|
|
|
/**
|
|
* \struct DRXAudBeep_t
|
|
* \brief Beep
|
|
*/
|
|
typedef struct {
|
|
s16 volume; /* dB */
|
|
u16 frequency; /* Hz */
|
|
bool mute;
|
|
} DRXAudBeep_t, *pDRXAudBeep_t;
|
|
|
|
/**
|
|
* \enum DRXAudBtscDetect_t
|
|
* \brief BTSC detetcion mode
|
|
*/
|
|
typedef enum {
|
|
DRX_BTSC_STEREO,
|
|
DRX_BTSC_MONO_AND_SAP
|
|
} DRXAudBtscDetect_t, *pDRXAudBtscDetect_t;
|
|
|
|
/**
|
|
* \struct DRXAudData_t
|
|
* \brief Audio data structure
|
|
*/
|
|
typedef struct {
|
|
/* audio storage */
|
|
bool audioIsActive;
|
|
DRXAudStandard_t audioStandard;
|
|
DRXCfgI2SOutput_t i2sdata;
|
|
DRXCfgAudVolume_t volume;
|
|
DRXCfgAudAutoSound_t autoSound;
|
|
DRXCfgAudASSThres_t assThresholds;
|
|
DRXCfgAudCarriers_t carriers;
|
|
DRXCfgAudMixer_t mixer;
|
|
DRXCfgAudDeviation_t deviation;
|
|
DRXCfgAudAVSync_t avSync;
|
|
DRXCfgAudPrescale_t prescale;
|
|
DRXAudFMDeemphasis_t deemph;
|
|
DRXAudBtscDetect_t btscDetect;
|
|
/* rds */
|
|
u16 rdsDataCounter;
|
|
bool rdsDataPresent;
|
|
} DRXAudData_t, *pDRXAudData_t;
|
|
|
|
/**
|
|
* \enum DRXQamLockRange_t
|
|
* \brief QAM lock range mode
|
|
*/
|
|
typedef enum {
|
|
DRX_QAM_LOCKRANGE_NORMAL,
|
|
DRX_QAM_LOCKRANGE_EXTENDED
|
|
} DRXQamLockRange_t, *pDRXQamLockRange_t;
|
|
|
|
/*============================================================================*/
|
|
/*============================================================================*/
|
|
/*== Data access structures ==================================================*/
|
|
/*============================================================================*/
|
|
/*============================================================================*/
|
|
|
|
/* Address on device */
|
|
typedef u32 DRXaddr_t, *pDRXaddr_t;
|
|
|
|
/* Protocol specific flags */
|
|
typedef u32 DRXflags_t, *pDRXflags_t;
|
|
|
|
/* Write block of data to device */
|
|
typedef int(*DRXWriteBlockFunc_t) (struct i2c_device_addr *devAddr, /* address of I2C device */
|
|
DRXaddr_t addr, /* address of register/memory */
|
|
u16 datasize, /* size of data in bytes */
|
|
u8 *data, /* data to send */
|
|
DRXflags_t flags);
|
|
|
|
/* Read block of data from device */
|
|
typedef int(*DRXReadBlockFunc_t) (struct i2c_device_addr *devAddr, /* address of I2C device */
|
|
DRXaddr_t addr, /* address of register/memory */
|
|
u16 datasize, /* size of data in bytes */
|
|
u8 *data, /* receive buffer */
|
|
DRXflags_t flags);
|
|
|
|
/* Write 8-bits value to device */
|
|
typedef int(*DRXWriteReg8Func_t) (struct i2c_device_addr *devAddr, /* address of I2C device */
|
|
DRXaddr_t addr, /* address of register/memory */
|
|
u8 data, /* data to send */
|
|
DRXflags_t flags);
|
|
|
|
/* Read 8-bits value to device */
|
|
typedef int(*DRXReadReg8Func_t) (struct i2c_device_addr *devAddr, /* address of I2C device */
|
|
DRXaddr_t addr, /* address of register/memory */
|
|
u8 *data, /* receive buffer */
|
|
DRXflags_t flags);
|
|
|
|
/* Read modify write 8-bits value to device */
|
|
typedef int(*DRXReadModifyWriteReg8Func_t) (struct i2c_device_addr *devAddr, /* address of I2C device */
|
|
DRXaddr_t waddr, /* write address of register */
|
|
DRXaddr_t raddr, /* read address of register */
|
|
u8 wdata, /* data to write */
|
|
u8 *rdata); /* data to read */
|
|
|
|
/* Write 16-bits value to device */
|
|
typedef int(*DRXWriteReg16Func_t) (struct i2c_device_addr *devAddr, /* address of I2C device */
|
|
DRXaddr_t addr, /* address of register/memory */
|
|
u16 data, /* data to send */
|
|
DRXflags_t flags);
|
|
|
|
/* Read 16-bits value to device */
|
|
typedef int(*DRXReadReg16Func_t) (struct i2c_device_addr *devAddr, /* address of I2C device */
|
|
DRXaddr_t addr, /* address of register/memory */
|
|
u16 *data, /* receive buffer */
|
|
DRXflags_t flags);
|
|
|
|
/* Read modify write 16-bits value to device */
|
|
typedef int(*DRXReadModifyWriteReg16Func_t) (struct i2c_device_addr *devAddr, /* address of I2C device */
|
|
DRXaddr_t waddr, /* write address of register */
|
|
DRXaddr_t raddr, /* read address of register */
|
|
u16 wdata, /* data to write */
|
|
u16 *rdata); /* data to read */
|
|
|
|
/* Write 32-bits value to device */
|
|
typedef int(*DRXWriteReg32Func_t) (struct i2c_device_addr *devAddr, /* address of I2C device */
|
|
DRXaddr_t addr, /* address of register/memory */
|
|
u32 data, /* data to send */
|
|
DRXflags_t flags);
|
|
|
|
/* Read 32-bits value to device */
|
|
typedef int(*DRXReadReg32Func_t) (struct i2c_device_addr *devAddr, /* address of I2C device */
|
|
DRXaddr_t addr, /* address of register/memory */
|
|
u32 *data, /* receive buffer */
|
|
DRXflags_t flags);
|
|
|
|
/* Read modify write 32-bits value to device */
|
|
typedef int(*DRXReadModifyWriteReg32Func_t) (struct i2c_device_addr *devAddr, /* address of I2C device */
|
|
DRXaddr_t waddr, /* write address of register */
|
|
DRXaddr_t raddr, /* read address of register */
|
|
u32 wdata, /* data to write */
|
|
u32 *rdata); /* data to read */
|
|
|
|
/**
|
|
* \struct DRXAccessFunc_t
|
|
* \brief Interface to an access protocol.
|
|
*/
|
|
typedef struct {
|
|
pDRXVersion_t protocolVersion;
|
|
DRXWriteBlockFunc_t writeBlockFunc;
|
|
DRXReadBlockFunc_t readBlockFunc;
|
|
DRXWriteReg8Func_t writeReg8Func;
|
|
DRXReadReg8Func_t readReg8Func;
|
|
DRXReadModifyWriteReg8Func_t readModifyWriteReg8Func;
|
|
DRXWriteReg16Func_t writeReg16Func;
|
|
DRXReadReg16Func_t readReg16Func;
|
|
DRXReadModifyWriteReg16Func_t readModifyWriteReg16Func;
|
|
DRXWriteReg32Func_t writeReg32Func;
|
|
DRXReadReg32Func_t readReg32Func;
|
|
DRXReadModifyWriteReg32Func_t readModifyWriteReg32Func;
|
|
} DRXAccessFunc_t, *pDRXAccessFunc_t;
|
|
|
|
/* Register address and data for register dump function */
|
|
typedef struct {
|
|
|
|
DRXaddr_t address;
|
|
u32 data;
|
|
|
|
} DRXRegDump_t, *pDRXRegDump_t;
|
|
|
|
/*============================================================================*/
|
|
/*============================================================================*/
|
|
/*== Demod instance data structures ==========================================*/
|
|
/*============================================================================*/
|
|
/*============================================================================*/
|
|
|
|
/**
|
|
* \struct DRXCommonAttr_t
|
|
* \brief Set of common attributes, shared by all DRX devices.
|
|
*/
|
|
typedef struct {
|
|
/* Microcode (firmware) attributes */
|
|
u8 *microcode; /**< Pointer to microcode image. */
|
|
u16 microcodeSize;
|
|
/**< Size of microcode image in bytes. */
|
|
bool verifyMicrocode;
|
|
/**< Use microcode verify or not. */
|
|
DRXMcVersionRec_t mcversion;
|
|
/**< Version record of microcode from file */
|
|
|
|
/* Clocks and tuner attributes */
|
|
s32 intermediateFreq;
|
|
/**< IF,if tuner instance not used. (kHz)*/
|
|
s32 sysClockFreq;
|
|
/**< Systemclock frequency. (kHz) */
|
|
s32 oscClockFreq;
|
|
/**< Oscillator clock frequency. (kHz) */
|
|
s16 oscClockDeviation;
|
|
/**< Oscillator clock deviation. (ppm) */
|
|
bool mirrorFreqSpect;
|
|
/**< Mirror IF frequency spectrum or not.*/
|
|
|
|
/* Initial MPEG output attributes */
|
|
DRXCfgMPEGOutput_t mpegCfg;
|
|
/**< MPEG configuration */
|
|
|
|
bool isOpened; /**< if true instance is already opened. */
|
|
|
|
/* Channel scan */
|
|
pDRXScanParam_t scanParam;
|
|
/**< scan parameters */
|
|
u16 scanFreqPlanIndex;
|
|
/**< next index in freq plan */
|
|
s32 scanNextFrequency;
|
|
/**< next freq to scan */
|
|
bool scanReady; /**< scan ready flag */
|
|
u32 scanMaxChannels;/**< number of channels in freqplan */
|
|
u32 scanChannelsScanned;
|
|
/**< number of channels scanned */
|
|
/* Channel scan - inner loop: demod related */
|
|
DRXScanFunc_t scanFunction;
|
|
/**< function to check channel */
|
|
/* Channel scan - inner loop: SYSObj related */
|
|
void *scanContext; /**< Context Pointer of SYSObj */
|
|
/* Channel scan - parameters for default DTV scan function in core driver */
|
|
u16 scanDemodLockTimeout;
|
|
/**< millisecs to wait for lock */
|
|
DRXLockStatus_t scanDesiredLock;
|
|
/**< lock requirement for channel found */
|
|
/* scanActive can be used by SetChannel to decide how to program the tuner,
|
|
fast or slow (but stable). Usually fast during scan. */
|
|
bool scanActive; /**< true when scan routines are active */
|
|
|
|
/* Power management */
|
|
DRXPowerMode_t currentPowerMode;
|
|
/**< current power management mode */
|
|
|
|
/* Tuner */
|
|
u8 tunerPortNr; /**< nr of I2C port to wich tuner is */
|
|
s32 tunerMinFreqRF;
|
|
/**< minimum RF input frequency, in kHz */
|
|
s32 tunerMaxFreqRF;
|
|
/**< maximum RF input frequency, in kHz */
|
|
bool tunerRfAgcPol; /**< if true invert RF AGC polarity */
|
|
bool tunerIfAgcPol; /**< if true invert IF AGC polarity */
|
|
bool tunerSlowMode; /**< if true invert IF AGC polarity */
|
|
|
|
DRXChannel_t currentChannel;
|
|
/**< current channel parameters */
|
|
enum drx_standard currentStandard;
|
|
/**< current standard selection */
|
|
enum drx_standard prevStandard;
|
|
/**< previous standard selection */
|
|
enum drx_standard diCacheStandard;
|
|
/**< standard in DI cache if available */
|
|
bool useBootloader; /**< use bootloader in open */
|
|
u32 capabilities; /**< capabilities flags */
|
|
u32 productId; /**< product ID inc. metal fix number */
|
|
|
|
} DRXCommonAttr_t, *pDRXCommonAttr_t;
|
|
|
|
/*
|
|
* Generic functions for DRX devices.
|
|
*/
|
|
typedef struct DRXDemodInstance_s *pDRXDemodInstance_t;
|
|
|
|
typedef int(*DRXOpenFunc_t) (pDRXDemodInstance_t demod);
|
|
typedef int(*DRXCloseFunc_t) (pDRXDemodInstance_t demod);
|
|
typedef int(*DRXCtrlFunc_t) (pDRXDemodInstance_t demod,
|
|
u32 ctrl,
|
|
void *ctrlData);
|
|
|
|
/**
|
|
* \struct DRXDemodFunc_t
|
|
* \brief A stucture containing all functions of a demodulator.
|
|
*/
|
|
typedef struct {
|
|
u32 typeId; /**< Device type identifier. */
|
|
DRXOpenFunc_t openFunc; /**< Pointer to Open() function. */
|
|
DRXCloseFunc_t closeFunc;/**< Pointer to Close() function. */
|
|
DRXCtrlFunc_t ctrlFunc; /**< Pointer to Ctrl() function. */
|
|
} DRXDemodFunc_t, *pDRXDemodFunc_t;
|
|
|
|
/**
|
|
* \struct DRXDemodInstance_t
|
|
* \brief Top structure of demodulator instance.
|
|
*/
|
|
typedef struct DRXDemodInstance_s {
|
|
/* type specific demodulator data */
|
|
pDRXDemodFunc_t myDemodFunct;
|
|
/**< demodulator functions */
|
|
pDRXAccessFunc_t myAccessFunct;
|
|
/**< data access protocol functions */
|
|
struct tuner_instance *myTuner;
|
|
/**< tuner instance,if NULL then baseband */
|
|
struct i2c_device_addr *myI2CDevAddr;
|
|
/**< i2c address and device identifier */
|
|
pDRXCommonAttr_t myCommonAttr;
|
|
/**< common DRX attributes */
|
|
void *myExtAttr; /**< device specific attributes */
|
|
/* generic demodulator data */
|
|
} DRXDemodInstance_t;
|
|
|
|
/*-------------------------------------------------------------------------
|
|
MACROS
|
|
Conversion from enum values to human readable form.
|
|
-------------------------------------------------------------------------*/
|
|
|
|
/* standard */
|
|
|
|
#define DRX_STR_STANDARD(x) ( \
|
|
( x == DRX_STANDARD_DVBT ) ? "DVB-T" : \
|
|
( x == DRX_STANDARD_8VSB ) ? "8VSB" : \
|
|
( x == DRX_STANDARD_NTSC ) ? "NTSC" : \
|
|
( x == DRX_STANDARD_PAL_SECAM_BG ) ? "PAL/SECAM B/G" : \
|
|
( x == DRX_STANDARD_PAL_SECAM_DK ) ? "PAL/SECAM D/K" : \
|
|
( x == DRX_STANDARD_PAL_SECAM_I ) ? "PAL/SECAM I" : \
|
|
( x == DRX_STANDARD_PAL_SECAM_L ) ? "PAL/SECAM L" : \
|
|
( x == DRX_STANDARD_PAL_SECAM_LP ) ? "PAL/SECAM LP" : \
|
|
( x == DRX_STANDARD_ITU_A ) ? "ITU-A" : \
|
|
( x == DRX_STANDARD_ITU_B ) ? "ITU-B" : \
|
|
( x == DRX_STANDARD_ITU_C ) ? "ITU-C" : \
|
|
( x == DRX_STANDARD_ITU_D ) ? "ITU-D" : \
|
|
( x == DRX_STANDARD_FM ) ? "FM" : \
|
|
( x == DRX_STANDARD_DTMB ) ? "DTMB" : \
|
|
( x == DRX_STANDARD_AUTO ) ? "Auto" : \
|
|
( x == DRX_STANDARD_UNKNOWN ) ? "Unknown" : \
|
|
"(Invalid)" )
|
|
|
|
/* channel */
|
|
|
|
#define DRX_STR_BANDWIDTH(x) ( \
|
|
( x == DRX_BANDWIDTH_8MHZ ) ? "8 MHz" : \
|
|
( x == DRX_BANDWIDTH_7MHZ ) ? "7 MHz" : \
|
|
( x == DRX_BANDWIDTH_6MHZ ) ? "6 MHz" : \
|
|
( x == DRX_BANDWIDTH_AUTO ) ? "Auto" : \
|
|
( x == DRX_BANDWIDTH_UNKNOWN ) ? "Unknown" : \
|
|
"(Invalid)" )
|
|
#define DRX_STR_FFTMODE(x) ( \
|
|
( x == DRX_FFTMODE_2K ) ? "2k" : \
|
|
( x == DRX_FFTMODE_4K ) ? "4k" : \
|
|
( x == DRX_FFTMODE_8K ) ? "8k" : \
|
|
( x == DRX_FFTMODE_AUTO ) ? "Auto" : \
|
|
( x == DRX_FFTMODE_UNKNOWN ) ? "Unknown" : \
|
|
"(Invalid)" )
|
|
#define DRX_STR_GUARD(x) ( \
|
|
( x == DRX_GUARD_1DIV32 ) ? "1/32nd" : \
|
|
( x == DRX_GUARD_1DIV16 ) ? "1/16th" : \
|
|
( x == DRX_GUARD_1DIV8 ) ? "1/8th" : \
|
|
( x == DRX_GUARD_1DIV4 ) ? "1/4th" : \
|
|
( x == DRX_GUARD_AUTO ) ? "Auto" : \
|
|
( x == DRX_GUARD_UNKNOWN ) ? "Unknown" : \
|
|
"(Invalid)" )
|
|
#define DRX_STR_CONSTELLATION(x) ( \
|
|
( x == DRX_CONSTELLATION_BPSK ) ? "BPSK" : \
|
|
( x == DRX_CONSTELLATION_QPSK ) ? "QPSK" : \
|
|
( x == DRX_CONSTELLATION_PSK8 ) ? "PSK8" : \
|
|
( x == DRX_CONSTELLATION_QAM16 ) ? "QAM16" : \
|
|
( x == DRX_CONSTELLATION_QAM32 ) ? "QAM32" : \
|
|
( x == DRX_CONSTELLATION_QAM64 ) ? "QAM64" : \
|
|
( x == DRX_CONSTELLATION_QAM128 ) ? "QAM128" : \
|
|
( x == DRX_CONSTELLATION_QAM256 ) ? "QAM256" : \
|
|
( x == DRX_CONSTELLATION_QAM512 ) ? "QAM512" : \
|
|
( x == DRX_CONSTELLATION_QAM1024 ) ? "QAM1024" : \
|
|
( x == DRX_CONSTELLATION_QPSK_NR ) ? "QPSK_NR" : \
|
|
( x == DRX_CONSTELLATION_AUTO ) ? "Auto" : \
|
|
( x == DRX_CONSTELLATION_UNKNOWN ) ? "Unknown" : \
|
|
"(Invalid)" )
|
|
#define DRX_STR_CODERATE(x) ( \
|
|
( x == DRX_CODERATE_1DIV2 ) ? "1/2nd" : \
|
|
( x == DRX_CODERATE_2DIV3 ) ? "2/3rd" : \
|
|
( x == DRX_CODERATE_3DIV4 ) ? "3/4th" : \
|
|
( x == DRX_CODERATE_5DIV6 ) ? "5/6th" : \
|
|
( x == DRX_CODERATE_7DIV8 ) ? "7/8th" : \
|
|
( x == DRX_CODERATE_AUTO ) ? "Auto" : \
|
|
( x == DRX_CODERATE_UNKNOWN ) ? "Unknown" : \
|
|
"(Invalid)" )
|
|
#define DRX_STR_HIERARCHY(x) ( \
|
|
( x == DRX_HIERARCHY_NONE ) ? "None" : \
|
|
( x == DRX_HIERARCHY_ALPHA1 ) ? "Alpha=1" : \
|
|
( x == DRX_HIERARCHY_ALPHA2 ) ? "Alpha=2" : \
|
|
( x == DRX_HIERARCHY_ALPHA4 ) ? "Alpha=4" : \
|
|
( x == DRX_HIERARCHY_AUTO ) ? "Auto" : \
|
|
( x == DRX_HIERARCHY_UNKNOWN ) ? "Unknown" : \
|
|
"(Invalid)" )
|
|
#define DRX_STR_PRIORITY(x) ( \
|
|
( x == DRX_PRIORITY_LOW ) ? "Low" : \
|
|
( x == DRX_PRIORITY_HIGH ) ? "High" : \
|
|
( x == DRX_PRIORITY_UNKNOWN ) ? "Unknown" : \
|
|
"(Invalid)" )
|
|
#define DRX_STR_MIRROR(x) ( \
|
|
( x == DRX_MIRROR_NO ) ? "Normal" : \
|
|
( x == DRX_MIRROR_YES ) ? "Mirrored" : \
|
|
( x == DRX_MIRROR_AUTO ) ? "Auto" : \
|
|
( x == DRX_MIRROR_UNKNOWN ) ? "Unknown" : \
|
|
"(Invalid)" )
|
|
#define DRX_STR_CLASSIFICATION(x) ( \
|
|
( x == DRX_CLASSIFICATION_GAUSS ) ? "Gaussion" : \
|
|
( x == DRX_CLASSIFICATION_HVY_GAUSS ) ? "Heavy Gaussion" : \
|
|
( x == DRX_CLASSIFICATION_COCHANNEL ) ? "Co-channel" : \
|
|
( x == DRX_CLASSIFICATION_STATIC ) ? "Static echo" : \
|
|
( x == DRX_CLASSIFICATION_MOVING ) ? "Moving echo" : \
|
|
( x == DRX_CLASSIFICATION_ZERODB ) ? "Zero dB echo" : \
|
|
( x == DRX_CLASSIFICATION_UNKNOWN ) ? "Unknown" : \
|
|
( x == DRX_CLASSIFICATION_AUTO ) ? "Auto" : \
|
|
"(Invalid)" )
|
|
|
|
#define DRX_STR_INTERLEAVEMODE(x) ( \
|
|
( x == DRX_INTERLEAVEMODE_I128_J1 ) ? "I128_J1" : \
|
|
( x == DRX_INTERLEAVEMODE_I128_J1_V2 ) ? "I128_J1_V2" : \
|
|
( x == DRX_INTERLEAVEMODE_I128_J2 ) ? "I128_J2" : \
|
|
( x == DRX_INTERLEAVEMODE_I64_J2 ) ? "I64_J2" : \
|
|
( x == DRX_INTERLEAVEMODE_I128_J3 ) ? "I128_J3" : \
|
|
( x == DRX_INTERLEAVEMODE_I32_J4 ) ? "I32_J4" : \
|
|
( x == DRX_INTERLEAVEMODE_I128_J4 ) ? "I128_J4" : \
|
|
( x == DRX_INTERLEAVEMODE_I16_J8 ) ? "I16_J8" : \
|
|
( x == DRX_INTERLEAVEMODE_I128_J5 ) ? "I128_J5" : \
|
|
( x == DRX_INTERLEAVEMODE_I8_J16 ) ? "I8_J16" : \
|
|
( x == DRX_INTERLEAVEMODE_I128_J6 ) ? "I128_J6" : \
|
|
( x == DRX_INTERLEAVEMODE_RESERVED_11 ) ? "Reserved 11" : \
|
|
( x == DRX_INTERLEAVEMODE_I128_J7 ) ? "I128_J7" : \
|
|
( x == DRX_INTERLEAVEMODE_RESERVED_13 ) ? "Reserved 13" : \
|
|
( x == DRX_INTERLEAVEMODE_I128_J8 ) ? "I128_J8" : \
|
|
( x == DRX_INTERLEAVEMODE_RESERVED_15 ) ? "Reserved 15" : \
|
|
( x == DRX_INTERLEAVEMODE_I12_J17 ) ? "I12_J17" : \
|
|
( x == DRX_INTERLEAVEMODE_I5_J4 ) ? "I5_J4" : \
|
|
( x == DRX_INTERLEAVEMODE_B52_M240 ) ? "B52_M240" : \
|
|
( x == DRX_INTERLEAVEMODE_B52_M720 ) ? "B52_M720" : \
|
|
( x == DRX_INTERLEAVEMODE_B52_M48 ) ? "B52_M48" : \
|
|
( x == DRX_INTERLEAVEMODE_B52_M0 ) ? "B52_M0" : \
|
|
( x == DRX_INTERLEAVEMODE_UNKNOWN ) ? "Unknown" : \
|
|
( x == DRX_INTERLEAVEMODE_AUTO ) ? "Auto" : \
|
|
"(Invalid)" )
|
|
|
|
#define DRX_STR_LDPC(x) ( \
|
|
( x == DRX_LDPC_0_4 ) ? "0.4" : \
|
|
( x == DRX_LDPC_0_6 ) ? "0.6" : \
|
|
( x == DRX_LDPC_0_8 ) ? "0.8" : \
|
|
( x == DRX_LDPC_AUTO ) ? "Auto" : \
|
|
( x == DRX_LDPC_UNKNOWN ) ? "Unknown" : \
|
|
"(Invalid)" )
|
|
|
|
#define DRX_STR_CARRIER(x) ( \
|
|
( x == DRX_CARRIER_MULTI ) ? "Multi" : \
|
|
( x == DRX_CARRIER_SINGLE ) ? "Single" : \
|
|
( x == DRX_CARRIER_AUTO ) ? "Auto" : \
|
|
( x == DRX_CARRIER_UNKNOWN ) ? "Unknown" : \
|
|
"(Invalid)" )
|
|
|
|
#define DRX_STR_FRAMEMODE(x) ( \
|
|
( x == DRX_FRAMEMODE_420 ) ? "420" : \
|
|
( x == DRX_FRAMEMODE_595 ) ? "595" : \
|
|
( x == DRX_FRAMEMODE_945 ) ? "945" : \
|
|
( x == DRX_FRAMEMODE_420_FIXED_PN ) ? "420 with fixed PN" : \
|
|
( x == DRX_FRAMEMODE_945_FIXED_PN ) ? "945 with fixed PN" : \
|
|
( x == DRX_FRAMEMODE_AUTO ) ? "Auto" : \
|
|
( x == DRX_FRAMEMODE_UNKNOWN ) ? "Unknown" : \
|
|
"(Invalid)" )
|
|
|
|
#define DRX_STR_PILOT(x) ( \
|
|
( x == DRX_PILOT_ON ) ? "On" : \
|
|
( x == DRX_PILOT_OFF ) ? "Off" : \
|
|
( x == DRX_PILOT_AUTO ) ? "Auto" : \
|
|
( x == DRX_PILOT_UNKNOWN ) ? "Unknown" : \
|
|
"(Invalid)" )
|
|
/* TPS */
|
|
|
|
#define DRX_STR_TPS_FRAME(x) ( \
|
|
( x == DRX_TPS_FRAME1 ) ? "Frame1" : \
|
|
( x == DRX_TPS_FRAME2 ) ? "Frame2" : \
|
|
( x == DRX_TPS_FRAME3 ) ? "Frame3" : \
|
|
( x == DRX_TPS_FRAME4 ) ? "Frame4" : \
|
|
( x == DRX_TPS_FRAME_UNKNOWN ) ? "Unknown" : \
|
|
"(Invalid)" )
|
|
|
|
/* lock status */
|
|
|
|
#define DRX_STR_LOCKSTATUS(x) ( \
|
|
( x == DRX_NEVER_LOCK ) ? "Never" : \
|
|
( x == DRX_NOT_LOCKED ) ? "No" : \
|
|
( x == DRX_LOCKED ) ? "Locked" : \
|
|
( x == DRX_LOCK_STATE_1 ) ? "Lock state 1" : \
|
|
( x == DRX_LOCK_STATE_2 ) ? "Lock state 2" : \
|
|
( x == DRX_LOCK_STATE_3 ) ? "Lock state 3" : \
|
|
( x == DRX_LOCK_STATE_4 ) ? "Lock state 4" : \
|
|
( x == DRX_LOCK_STATE_5 ) ? "Lock state 5" : \
|
|
( x == DRX_LOCK_STATE_6 ) ? "Lock state 6" : \
|
|
( x == DRX_LOCK_STATE_7 ) ? "Lock state 7" : \
|
|
( x == DRX_LOCK_STATE_8 ) ? "Lock state 8" : \
|
|
( x == DRX_LOCK_STATE_9 ) ? "Lock state 9" : \
|
|
"(Invalid)" )
|
|
|
|
/* version information , modules */
|
|
#define DRX_STR_MODULE(x) ( \
|
|
( x == DRX_MODULE_DEVICE ) ? "Device" : \
|
|
( x == DRX_MODULE_MICROCODE ) ? "Microcode" : \
|
|
( x == DRX_MODULE_DRIVERCORE ) ? "CoreDriver" : \
|
|
( x == DRX_MODULE_DEVICEDRIVER ) ? "DeviceDriver" : \
|
|
( x == DRX_MODULE_BSP_I2C ) ? "BSP I2C" : \
|
|
( x == DRX_MODULE_BSP_TUNER ) ? "BSP Tuner" : \
|
|
( x == DRX_MODULE_BSP_HOST ) ? "BSP Host" : \
|
|
( x == DRX_MODULE_DAP ) ? "Data Access Protocol" : \
|
|
( x == DRX_MODULE_UNKNOWN ) ? "Unknown" : \
|
|
"(Invalid)" )
|
|
|
|
#define DRX_STR_POWER_MODE(x) ( \
|
|
( x == DRX_POWER_UP ) ? "DRX_POWER_UP " : \
|
|
( x == DRX_POWER_MODE_1 ) ? "DRX_POWER_MODE_1" : \
|
|
( x == DRX_POWER_MODE_2 ) ? "DRX_POWER_MODE_2" : \
|
|
( x == DRX_POWER_MODE_3 ) ? "DRX_POWER_MODE_3" : \
|
|
( x == DRX_POWER_MODE_4 ) ? "DRX_POWER_MODE_4" : \
|
|
( x == DRX_POWER_MODE_5 ) ? "DRX_POWER_MODE_5" : \
|
|
( x == DRX_POWER_MODE_6 ) ? "DRX_POWER_MODE_6" : \
|
|
( x == DRX_POWER_MODE_7 ) ? "DRX_POWER_MODE_7" : \
|
|
( x == DRX_POWER_MODE_8 ) ? "DRX_POWER_MODE_8" : \
|
|
( x == DRX_POWER_MODE_9 ) ? "DRX_POWER_MODE_9" : \
|
|
( x == DRX_POWER_MODE_10 ) ? "DRX_POWER_MODE_10" : \
|
|
( x == DRX_POWER_MODE_11 ) ? "DRX_POWER_MODE_11" : \
|
|
( x == DRX_POWER_MODE_12 ) ? "DRX_POWER_MODE_12" : \
|
|
( x == DRX_POWER_MODE_13 ) ? "DRX_POWER_MODE_13" : \
|
|
( x == DRX_POWER_MODE_14 ) ? "DRX_POWER_MODE_14" : \
|
|
( x == DRX_POWER_MODE_15 ) ? "DRX_POWER_MODE_15" : \
|
|
( x == DRX_POWER_MODE_16 ) ? "DRX_POWER_MODE_16" : \
|
|
( x == DRX_POWER_DOWN ) ? "DRX_POWER_DOWN " : \
|
|
"(Invalid)" )
|
|
|
|
#define DRX_STR_OOB_STANDARD(x) ( \
|
|
( x == DRX_OOB_MODE_A ) ? "ANSI 55-1 " : \
|
|
( x == DRX_OOB_MODE_B_GRADE_A ) ? "ANSI 55-2 A" : \
|
|
( x == DRX_OOB_MODE_B_GRADE_B ) ? "ANSI 55-2 B" : \
|
|
"(Invalid)" )
|
|
|
|
#define DRX_STR_AUD_STANDARD(x) ( \
|
|
( x == DRX_AUD_STANDARD_BTSC ) ? "BTSC" : \
|
|
( x == DRX_AUD_STANDARD_A2 ) ? "A2" : \
|
|
( x == DRX_AUD_STANDARD_EIAJ ) ? "EIAJ" : \
|
|
( x == DRX_AUD_STANDARD_FM_STEREO ) ? "FM Stereo" : \
|
|
( x == DRX_AUD_STANDARD_AUTO ) ? "Auto" : \
|
|
( x == DRX_AUD_STANDARD_M_MONO ) ? "M-Standard Mono" : \
|
|
( x == DRX_AUD_STANDARD_D_K_MONO ) ? "D/K Mono FM" : \
|
|
( x == DRX_AUD_STANDARD_BG_FM ) ? "B/G-Dual Carrier FM (A2)" : \
|
|
( x == DRX_AUD_STANDARD_D_K1 ) ? "D/K1-Dual Carrier FM" : \
|
|
( x == DRX_AUD_STANDARD_D_K2 ) ? "D/K2-Dual Carrier FM" : \
|
|
( x == DRX_AUD_STANDARD_D_K3 ) ? "D/K3-Dual Carrier FM" : \
|
|
( x == DRX_AUD_STANDARD_BG_NICAM_FM ) ? "B/G-NICAM-FM" : \
|
|
( x == DRX_AUD_STANDARD_L_NICAM_AM ) ? "L-NICAM-AM" : \
|
|
( x == DRX_AUD_STANDARD_I_NICAM_FM ) ? "I-NICAM-FM" : \
|
|
( x == DRX_AUD_STANDARD_D_K_NICAM_FM ) ? "D/K-NICAM-FM" : \
|
|
( x == DRX_AUD_STANDARD_UNKNOWN ) ? "Unknown" : \
|
|
"(Invalid)" )
|
|
#define DRX_STR_AUD_STEREO(x) ( \
|
|
( x == true ) ? "Stereo" : \
|
|
( x == false ) ? "Mono" : \
|
|
"(Invalid)" )
|
|
|
|
#define DRX_STR_AUD_SAP(x) ( \
|
|
( x == true ) ? "Present" : \
|
|
( x == false ) ? "Not present" : \
|
|
"(Invalid)" )
|
|
|
|
#define DRX_STR_AUD_CARRIER(x) ( \
|
|
( x == true ) ? "Present" : \
|
|
( x == false ) ? "Not present" : \
|
|
"(Invalid)" )
|
|
|
|
#define DRX_STR_AUD_RDS(x) ( \
|
|
( x == true ) ? "Available" : \
|
|
( x == false ) ? "Not Available" : \
|
|
"(Invalid)" )
|
|
|
|
#define DRX_STR_AUD_NICAM_STATUS(x) ( \
|
|
( x == DRX_AUD_NICAM_DETECTED ) ? "Detected" : \
|
|
( x == DRX_AUD_NICAM_NOT_DETECTED ) ? "Not detected" : \
|
|
( x == DRX_AUD_NICAM_BAD ) ? "Bad" : \
|
|
"(Invalid)" )
|
|
|
|
#define DRX_STR_RDS_VALID(x) ( \
|
|
( x == true ) ? "Valid" : \
|
|
( x == false ) ? "Not Valid" : \
|
|
"(Invalid)" )
|
|
|
|
/*-------------------------------------------------------------------------
|
|
Access macros
|
|
-------------------------------------------------------------------------*/
|
|
|
|
/**
|
|
* \brief Create a compilable reference to the microcode attribute
|
|
* \param d pointer to demod instance
|
|
*
|
|
* Used as main reference to an attribute field.
|
|
* Used by both macro implementation and function implementation.
|
|
* These macros are defined to avoid duplication of code in macro and function
|
|
* definitions that handle access of demod common or extended attributes.
|
|
*
|
|
*/
|
|
|
|
#define DRX_ATTR_MCRECORD( d ) ((d)->myCommonAttr->mcversion)
|
|
#define DRX_ATTR_MIRRORFREQSPECT( d ) ((d)->myCommonAttr->mirrorFreqSpect)
|
|
#define DRX_ATTR_CURRENTPOWERMODE( d )((d)->myCommonAttr->currentPowerMode)
|
|
#define DRX_ATTR_ISOPENED( d ) ((d)->myCommonAttr->isOpened)
|
|
#define DRX_ATTR_USEBOOTLOADER( d ) ((d)->myCommonAttr->useBootloader)
|
|
#define DRX_ATTR_CURRENTSTANDARD( d ) ((d)->myCommonAttr->currentStandard)
|
|
#define DRX_ATTR_PREVSTANDARD( d ) ((d)->myCommonAttr->prevStandard)
|
|
#define DRX_ATTR_CACHESTANDARD( d ) ((d)->myCommonAttr->diCacheStandard)
|
|
#define DRX_ATTR_CURRENTCHANNEL( d ) ((d)->myCommonAttr->currentChannel)
|
|
#define DRX_ATTR_MICROCODE( d ) ((d)->myCommonAttr->microcode)
|
|
#define DRX_ATTR_MICROCODESIZE( d ) ((d)->myCommonAttr->microcodeSize)
|
|
#define DRX_ATTR_VERIFYMICROCODE( d ) ((d)->myCommonAttr->verifyMicrocode)
|
|
#define DRX_ATTR_CAPABILITIES( d ) ((d)->myCommonAttr->capabilities)
|
|
#define DRX_ATTR_PRODUCTID( d ) ((d)->myCommonAttr->productId)
|
|
#define DRX_ATTR_INTERMEDIATEFREQ( d) ((d)->myCommonAttr->intermediateFreq)
|
|
#define DRX_ATTR_SYSCLOCKFREQ( d) ((d)->myCommonAttr->sysClockFreq)
|
|
#define DRX_ATTR_TUNERRFAGCPOL( d ) ((d)->myCommonAttr->tunerRfAgcPol)
|
|
#define DRX_ATTR_TUNERIFAGCPOL( d) ((d)->myCommonAttr->tunerIfAgcPol)
|
|
#define DRX_ATTR_TUNERSLOWMODE( d) ((d)->myCommonAttr->tunerSlowMode)
|
|
#define DRX_ATTR_TUNERSPORTNR( d) ((d)->myCommonAttr->tunerPortNr)
|
|
#define DRX_ATTR_TUNER( d ) ((d)->myTuner)
|
|
#define DRX_ATTR_I2CADDR( d ) ((d)->myI2CDevAddr->i2cAddr)
|
|
#define DRX_ATTR_I2CDEVID( d ) ((d)->myI2CDevAddr->i2cDevId)
|
|
|
|
/**
|
|
* \brief Actual access macro's
|
|
* \param d pointer to demod instance
|
|
* \param x value to set ar to get
|
|
*
|
|
* SET macro's must be used to set the value of an attribute.
|
|
* GET macro's must be used to retrieve the value of an attribute.
|
|
*
|
|
*/
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_MIRRORFREQSPECT( d, x ) \
|
|
do { \
|
|
DRX_ATTR_MIRRORFREQSPECT( d ) = (x); \
|
|
} while(0)
|
|
|
|
#define DRX_GET_MIRRORFREQSPECT( d, x ) \
|
|
do { \
|
|
(x)=DRX_ATTR_MIRRORFREQSPECT( d ); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_CURRENTPOWERMODE( d, x ) \
|
|
do { \
|
|
DRX_ATTR_CURRENTPOWERMODE( d ) = (x); \
|
|
} while(0)
|
|
|
|
#define DRX_GET_CURRENTPOWERMODE( d, x ) \
|
|
do { \
|
|
(x)=DRX_ATTR_CURRENTPOWERMODE( d ); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_MICROCODE( d, x ) \
|
|
do { \
|
|
DRX_ATTR_MICROCODE( d ) = (x); \
|
|
} while(0)
|
|
|
|
#define DRX_GET_MICROCODE( d, x ) \
|
|
do { \
|
|
(x)=DRX_ATTR_MICROCODE( d ); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_MICROCODESIZE( d, x ) \
|
|
do { \
|
|
DRX_ATTR_MICROCODESIZE(d) = (x); \
|
|
} while(0)
|
|
|
|
#define DRX_GET_MICROCODESIZE( d, x ) \
|
|
do { \
|
|
(x)=DRX_ATTR_MICROCODESIZE(d); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_VERIFYMICROCODE( d, x ) \
|
|
do { \
|
|
DRX_ATTR_VERIFYMICROCODE(d) = (x); \
|
|
} while(0)
|
|
|
|
#define DRX_GET_VERIFYMICROCODE( d, x ) \
|
|
do { \
|
|
(x)=DRX_ATTR_VERIFYMICROCODE(d); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_MCVERTYPE( d, x ) \
|
|
do { \
|
|
DRX_ATTR_MCRECORD(d).auxType = (x); \
|
|
} while (0)
|
|
|
|
#define DRX_GET_MCVERTYPE( d, x ) \
|
|
do { \
|
|
(x) = DRX_ATTR_MCRECORD(d).auxType; \
|
|
} while (0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_ISMCVERTYPE(x) ((x) == AUX_VER_RECORD)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_MCDEV( d, x ) \
|
|
do { \
|
|
DRX_ATTR_MCRECORD(d).mcDevType = (x); \
|
|
} while (0)
|
|
|
|
#define DRX_GET_MCDEV( d, x ) \
|
|
do { \
|
|
(x) = DRX_ATTR_MCRECORD(d).mcDevType; \
|
|
} while (0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_MCVERSION( d, x ) \
|
|
do { \
|
|
DRX_ATTR_MCRECORD(d).mcVersion = (x); \
|
|
} while (0)
|
|
|
|
#define DRX_GET_MCVERSION( d, x ) \
|
|
do { \
|
|
(x) = DRX_ATTR_MCRECORD(d).mcVersion; \
|
|
} while (0)
|
|
|
|
/**************************/
|
|
#define DRX_SET_MCPATCH( d, x ) \
|
|
do { \
|
|
DRX_ATTR_MCRECORD(d).mcBaseVersion = (x); \
|
|
} while (0)
|
|
|
|
#define DRX_GET_MCPATCH( d, x ) \
|
|
do { \
|
|
(x) = DRX_ATTR_MCRECORD(d).mcBaseVersion; \
|
|
} while (0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_I2CADDR( d, x ) \
|
|
do { \
|
|
DRX_ATTR_I2CADDR(d) = (x); \
|
|
} while(0)
|
|
|
|
#define DRX_GET_I2CADDR( d, x ) \
|
|
do { \
|
|
(x)=DRX_ATTR_I2CADDR(d); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_I2CDEVID( d, x ) \
|
|
do { \
|
|
DRX_ATTR_I2CDEVID(d) = (x); \
|
|
} while(0)
|
|
|
|
#define DRX_GET_I2CDEVID( d, x ) \
|
|
do { \
|
|
(x)=DRX_ATTR_I2CDEVID(d); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_USEBOOTLOADER( d, x ) \
|
|
do { \
|
|
DRX_ATTR_USEBOOTLOADER(d) = (x); \
|
|
} while(0)
|
|
|
|
#define DRX_GET_USEBOOTLOADER( d, x) \
|
|
do { \
|
|
(x)=DRX_ATTR_USEBOOTLOADER(d); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_CURRENTSTANDARD( d, x ) \
|
|
do { \
|
|
DRX_ATTR_CURRENTSTANDARD(d) = (x); \
|
|
} while(0)
|
|
|
|
#define DRX_GET_CURRENTSTANDARD( d, x) \
|
|
do { \
|
|
(x)=DRX_ATTR_CURRENTSTANDARD(d); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_PREVSTANDARD( d, x ) \
|
|
do { \
|
|
DRX_ATTR_PREVSTANDARD(d) = (x); \
|
|
} while(0)
|
|
|
|
#define DRX_GET_PREVSTANDARD( d, x) \
|
|
do { \
|
|
(x)=DRX_ATTR_PREVSTANDARD(d); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_CACHESTANDARD( d, x ) \
|
|
do { \
|
|
DRX_ATTR_CACHESTANDARD(d) = (x); \
|
|
} while(0)
|
|
|
|
#define DRX_GET_CACHESTANDARD( d, x) \
|
|
do { \
|
|
(x)=DRX_ATTR_CACHESTANDARD(d); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_CURRENTCHANNEL( d, x ) \
|
|
do { \
|
|
DRX_ATTR_CURRENTCHANNEL(d) = (x); \
|
|
} while(0)
|
|
|
|
#define DRX_GET_CURRENTCHANNEL( d, x) \
|
|
do { \
|
|
(x)=DRX_ATTR_CURRENTCHANNEL(d); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_ISOPENED( d, x ) \
|
|
do { \
|
|
DRX_ATTR_ISOPENED(d) = (x); \
|
|
} while(0)
|
|
|
|
#define DRX_GET_ISOPENED( d, x) \
|
|
do { \
|
|
(x) = DRX_ATTR_ISOPENED(d); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_TUNER( d, x ) \
|
|
do { \
|
|
DRX_ATTR_TUNER(d) = (x); \
|
|
} while(0)
|
|
|
|
#define DRX_GET_TUNER( d, x) \
|
|
do { \
|
|
(x) = DRX_ATTR_TUNER(d); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_CAPABILITIES( d, x ) \
|
|
do { \
|
|
DRX_ATTR_CAPABILITIES(d) = (x); \
|
|
} while(0)
|
|
|
|
#define DRX_GET_CAPABILITIES( d, x) \
|
|
do { \
|
|
(x) = DRX_ATTR_CAPABILITIES(d); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_PRODUCTID( d, x ) \
|
|
do { \
|
|
DRX_ATTR_PRODUCTID(d) |= (x << 4); \
|
|
} while(0)
|
|
|
|
#define DRX_GET_PRODUCTID( d, x) \
|
|
do { \
|
|
(x) = (DRX_ATTR_PRODUCTID(d) >> 4); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_MFX( d, x ) \
|
|
do { \
|
|
DRX_ATTR_PRODUCTID(d) |= (x); \
|
|
} while(0)
|
|
|
|
#define DRX_GET_MFX( d, x) \
|
|
do { \
|
|
(x) = (DRX_ATTR_PRODUCTID(d) & 0xF); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_INTERMEDIATEFREQ( d, x ) \
|
|
do { \
|
|
DRX_ATTR_INTERMEDIATEFREQ(d) = (x); \
|
|
} while(0)
|
|
|
|
#define DRX_GET_INTERMEDIATEFREQ( d, x) \
|
|
do { \
|
|
(x) = DRX_ATTR_INTERMEDIATEFREQ(d); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_SYSCLOCKFREQ( d, x ) \
|
|
do { \
|
|
DRX_ATTR_SYSCLOCKFREQ(d) = (x); \
|
|
} while(0)
|
|
|
|
#define DRX_GET_SYSCLOCKFREQ( d, x) \
|
|
do { \
|
|
(x) = DRX_ATTR_SYSCLOCKFREQ(d); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_TUNERRFAGCPOL( d, x ) \
|
|
do { \
|
|
DRX_ATTR_TUNERRFAGCPOL(d) = (x); \
|
|
} while(0)
|
|
|
|
#define DRX_GET_TUNERRFAGCPOL( d, x) \
|
|
do { \
|
|
(x) = DRX_ATTR_TUNERRFAGCPOL(d); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_TUNERIFAGCPOL( d, x ) \
|
|
do { \
|
|
DRX_ATTR_TUNERIFAGCPOL(d) = (x); \
|
|
} while(0)
|
|
|
|
#define DRX_GET_TUNERIFAGCPOL( d, x) \
|
|
do { \
|
|
(x) = DRX_ATTR_TUNERIFAGCPOL(d); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_TUNERSLOWMODE( d, x ) \
|
|
do { \
|
|
DRX_ATTR_TUNERSLOWMODE(d) = (x); \
|
|
} while(0)
|
|
|
|
#define DRX_GET_TUNERSLOWMODE( d, x) \
|
|
do { \
|
|
(x) = DRX_ATTR_TUNERSLOWMODE(d); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
#define DRX_SET_TUNERPORTNR( d, x ) \
|
|
do { \
|
|
DRX_ATTR_TUNERSPORTNR(d) = (x); \
|
|
} while(0)
|
|
|
|
/**************************/
|
|
|
|
/* Macros with device-specific handling are converted to CFG functions */
|
|
|
|
#define DRX_ACCESSMACRO_SET( demod, value, cfgName, dataType ) \
|
|
do { \
|
|
DRXCfg_t config; \
|
|
dataType cfgData; \
|
|
config.cfgType = cfgName; \
|
|
config.cfgData = &cfgData; \
|
|
cfgData = value; \
|
|
DRX_Ctrl( demod, DRX_CTRL_SET_CFG, &config ); \
|
|
} while ( 0 )
|
|
|
|
#define DRX_ACCESSMACRO_GET( demod, value, cfgName, dataType, errorValue ) \
|
|
do { \
|
|
int cfgStatus; \
|
|
DRXCfg_t config; \
|
|
dataType cfgData; \
|
|
config.cfgType = cfgName; \
|
|
config.cfgData = &cfgData; \
|
|
cfgStatus = DRX_Ctrl( demod, DRX_CTRL_GET_CFG, &config ); \
|
|
if ( cfgStatus == DRX_STS_OK ) { \
|
|
value = cfgData; \
|
|
} else { \
|
|
value = (dataType)errorValue; \
|
|
} \
|
|
} while ( 0 )
|
|
|
|
/* Configuration functions for usage by Access (XS) Macros */
|
|
|
|
#ifndef DRX_XS_CFG_BASE
|
|
#define DRX_XS_CFG_BASE (500)
|
|
#endif
|
|
|
|
#define DRX_XS_CFG_PRESET ( DRX_XS_CFG_BASE + 0 )
|
|
#define DRX_XS_CFG_AUD_BTSC_DETECT ( DRX_XS_CFG_BASE + 1 )
|
|
#define DRX_XS_CFG_QAM_LOCKRANGE ( DRX_XS_CFG_BASE + 2 )
|
|
|
|
/* Access Macros with device-specific handling */
|
|
|
|
#define DRX_SET_PRESET( d, x ) \
|
|
DRX_ACCESSMACRO_SET( (d), (x), DRX_XS_CFG_PRESET, char* )
|
|
#define DRX_GET_PRESET( d, x ) \
|
|
DRX_ACCESSMACRO_GET( (d), (x), DRX_XS_CFG_PRESET, char*, "ERROR" )
|
|
|
|
#define DRX_SET_AUD_BTSC_DETECT( d, x ) DRX_ACCESSMACRO_SET( (d), (x), \
|
|
DRX_XS_CFG_AUD_BTSC_DETECT, DRXAudBtscDetect_t )
|
|
#define DRX_GET_AUD_BTSC_DETECT( d, x ) DRX_ACCESSMACRO_GET( (d), (x), \
|
|
DRX_XS_CFG_AUD_BTSC_DETECT, DRXAudBtscDetect_t, DRX_UNKNOWN )
|
|
|
|
#define DRX_SET_QAM_LOCKRANGE( d, x ) DRX_ACCESSMACRO_SET( (d), (x), \
|
|
DRX_XS_CFG_QAM_LOCKRANGE, DRXQamLockRange_t )
|
|
#define DRX_GET_QAM_LOCKRANGE( d, x ) DRX_ACCESSMACRO_GET( (d), (x), \
|
|
DRX_XS_CFG_QAM_LOCKRANGE, DRXQamLockRange_t, DRX_UNKNOWN )
|
|
|
|
/**
|
|
* \brief Macro to check if std is an ATV standard
|
|
* \retval true std is an ATV standard
|
|
* \retval false std is an ATV standard
|
|
*/
|
|
#define DRX_ISATVSTD( std ) ( ( (std) == DRX_STANDARD_PAL_SECAM_BG ) || \
|
|
( (std) == DRX_STANDARD_PAL_SECAM_DK ) || \
|
|
( (std) == DRX_STANDARD_PAL_SECAM_I ) || \
|
|
( (std) == DRX_STANDARD_PAL_SECAM_L ) || \
|
|
( (std) == DRX_STANDARD_PAL_SECAM_LP ) || \
|
|
( (std) == DRX_STANDARD_NTSC ) || \
|
|
( (std) == DRX_STANDARD_FM ) )
|
|
|
|
/**
|
|
* \brief Macro to check if std is an QAM standard
|
|
* \retval true std is an QAM standards
|
|
* \retval false std is an QAM standards
|
|
*/
|
|
#define DRX_ISQAMSTD( std ) ( ( (std) == DRX_STANDARD_ITU_A ) || \
|
|
( (std) == DRX_STANDARD_ITU_B ) || \
|
|
( (std) == DRX_STANDARD_ITU_C ) || \
|
|
( (std) == DRX_STANDARD_ITU_D ))
|
|
|
|
/**
|
|
* \brief Macro to check if std is VSB standard
|
|
* \retval true std is VSB standard
|
|
* \retval false std is not VSB standard
|
|
*/
|
|
#define DRX_ISVSBSTD( std ) ( (std) == DRX_STANDARD_8VSB )
|
|
|
|
/**
|
|
* \brief Macro to check if std is DVBT standard
|
|
* \retval true std is DVBT standard
|
|
* \retval false std is not DVBT standard
|
|
*/
|
|
#define DRX_ISDVBTSTD( std ) ( (std) == DRX_STANDARD_DVBT )
|
|
|
|
/*-------------------------------------------------------------------------
|
|
Exported FUNCTIONS
|
|
-------------------------------------------------------------------------*/
|
|
|
|
int DRX_Init(pDRXDemodInstance_t demods[]);
|
|
|
|
int DRX_Term(void);
|
|
|
|
int DRX_Open(pDRXDemodInstance_t demod);
|
|
|
|
int DRX_Close(pDRXDemodInstance_t demod);
|
|
|
|
int DRX_Ctrl(pDRXDemodInstance_t demod,
|
|
u32 ctrl, void *ctrlData);
|
|
|
|
/*-------------------------------------------------------------------------
|
|
THE END
|
|
-------------------------------------------------------------------------*/
|
|
#endif /* __DRXDRIVER_H__ */
|