33. The SI476x Driver

Copyright © 2013 Andrey Smirnov <andrew.smirnov@gmail.com>

33.1. TODO for the driver

  • According to the SiLabs’ datasheet it is possible to update the firmware of the radio chip in the run-time, thus bringing it to the most recent version. Unfortunately I couldn’t find any mentioning of the said firmware update for the old chips that I tested the driver against, so for chips like that the driver only exposes the old functionality.

33.2. Parameters exposed over debugfs

SI476x allow user to get multiple characteristics that can be very useful for EoL testing/RF performance estimation, parameters that have very little to do with V4L2 subsystem. Such parameters are exposed via debugfs and can be accessed via regular file I/O operations.

The drivers exposes following files:

  • /sys/kernel/debug/<device-name>/acf This file contains ACF(Automatically Controlled Features) status information. The contents of the file is binary data of the following layout:

    Offset

    Name

    Description

    0x00

    blend_int

    Flag, set when stereo separation has crossed below the blend threshold

    0x01

    hblend_int

    Flag, set when HiBlend cutoff frequency is lower than threshold

    0x02

    hicut_int

    Flag, set when HiCut cutoff frequency is lower than threshold

    0x03

    chbw_int

    Flag, set when channel filter bandwidth is less than threshold

    0x04

    softmute_int

    Flag indicating that softmute attenuation has increased above softmute threshold

    0x05

    smute

    0 - Audio is not soft muted 1 - Audio is soft muted

    0x06

    smattn

    Soft mute attenuation level in dB

    0x07

    chbw

    Channel filter bandwidth in kHz

    0x08

    hicut

    HiCut cutoff frequency in units of 100Hz

    0x09

    hiblend

    HiBlend cutoff frequency in units of 100 Hz

    0x10

    pilot

    0 - Stereo pilot is not present 1 - Stereo pilot is present

    0x11

    stblend

    Stereo blend in %

  • /sys/kernel/debug/<device-name>/rds_blckcnt This file contains statistics about RDS receptions. It’s binary data has the following layout:

    Offset

    Name

    Description

    0x00

    expected

    Number of expected RDS blocks

    0x02

    received

    Number of received RDS blocks

    0x04

    uncorrectable

    Number of uncorrectable RDS blocks

  • /sys/kernel/debug/<device-name>/agc This file contains information about parameters pertaining to AGC(Automatic Gain Control)

    The layout is:

    Offset

    Name

    Description

    0x00

    mxhi

    0 - FM Mixer PD high threshold is not tripped 1 - FM Mixer PD high threshold is tripped

    0x01

    mxlo

    ditto for FM Mixer PD low

    0x02

    lnahi

    ditto for FM LNA PD high

    0x03

    lnalo

    ditto for FM LNA PD low

    0x04

    fmagc1

    FMAGC1 attenuator resistance (see datasheet for more detail)

    0x05

    fmagc2

    ditto for FMAGC2

    0x06

    pgagain

    PGA gain in dB

    0x07

    fmwblang

    FM/WB LNA Gain in dB

  • /sys/kernel/debug/<device-name>/rsq This file contains information about parameters pertaining to RSQ(Received Signal Quality)

    The layout is:

    Offset

    Name

    Description

    0x00

    multhint

    0 - multipath value has not crossed the Multipath high threshold 1 - multipath value has crossed the Multipath high threshold

    0x01

    multlint

    ditto for Multipath low threshold

    0x02

    snrhint

    0 - received signal’s SNR has not crossed high threshold 1 - received signal’s SNR has crossed high threshold

    0x03

    snrlint

    ditto for low threshold

    0x04

    rssihint

    ditto for RSSI high threshold

    0x05

    rssilint

    ditto for RSSI low threshold

    0x06

    bltf

    Flag indicating if seek command reached/wrapped seek band limit

    0x07

    snr_ready

    Indicates that SNR metrics is ready

    0x08

    rssiready

    ditto for RSSI metrics

    0x09

    injside

    0 - Low-side injection is being used 1 - High-side injection is used

    0x10

    afcrl

    Flag indicating if AFC rails

    0x11

    valid

    Flag indicating if channel is valid

    0x12

    readfreq

    Current tuned frequency

    0x14

    freqoff

    Signed frequency offset in units of 2ppm

    0x15

    rssi

    Signed value of RSSI in dBuV

    0x16

    snr

    Signed RF SNR in dB

    0x17

    issi

    Signed Image Strength Signal indicator

    0x18

    lassi

    Signed Low side adjacent Channel Strength indicator

    0x19

    hassi

    ditto fpr High side

    0x20

    mult

    Multipath indicator

    0x21

    dev

    Frequency deviation

    0x24

    assi

    Adjacent channel SSI

    0x25

    usn

    Ultrasonic noise indicator

    0x26

    pilotdev

    Pilot deviation in units of 100 Hz

    0x27

    rdsdev

    ditto for RDS

    0x28

    assidev

    ditto for ASSI

    0x29

    strongdev

    Frequency deviation

    0x30

    rdspi

    RDS PI code

  • /sys/kernel/debug/<device-name>/rsq_primary This file contains information about parameters pertaining to RSQ(Received Signal Quality) for primary tuner only. Layout is as the one above.