Post Go back to editing

adrv9002 LO change is very slow

I am using the adrv9002 eval board.
All seems to be working correctly.

However, changing the LO seems to take about 200mS which is quite slow.

I am changing this through 

out_altvoltage0_RX1_LO_frequency via sysfs.

How can I speed this up?

I would like to scan from 30M to 6G as fast as possible.

With the slow LO change this takes 30 seconds, which is very slow.

Maybe SPI clock running slow? If so, how would I change this?

Thanks for the help



Top Replies

    •  Analog Employees 
    in reply to swie +1 verified
    However, setting  in_voltage0_ensm_mode back to rf_enabled takes a long time.

    In this case, I believe the PLL will only retune when you move the port to rf_enabled which will add more time to an…

  • In Vivado the ARM SPI clock is set to 187.5MHz, so this should be fast.
    I am not sure if the driver sets the clock to a slower frequency?

    Thanks

  • You are not bound by SPI here. When changing the LO by 100 MHz from an original point the part must be recalibrated. This can take some time. See page 86 of the user guide.

    -Travis

  • Hi Travis,

    Thanks for the response.
    I tried to disable the calibrations: automatic gain control (RX_AGC), baseband DC offset (RX_BBDC), (2nd order) harmonic distortion (RX_HD2), frequency independent QEC (RX_QEC_FIC) and frequency dependent QEC for WB (RX_QEC_WBPOLY).

    However, tuning still takes 200mS.

    Can I turn off some other calibrations to speed this up?
    I realize there may be some error in the data due to not being calibrated.

    However, I would still like to do this.

    Thanks

  • You cannot disable this calibration since the PLL driving the mixer will not lock.

    The only alternative is to use fast hopping but this is not supported in the Linux driver yet.

    -Travis

  • Thanks Travis,

    Is there an estimated time when fast hopping will be supported in the driver?

  • Changing LOs can indeed take some time.. On top of having to re-lock the PLL, the port also has to be moved to the calibrated state and then back to rf_enabled. Moving it back to rf_enabled can also take some time but way less than the 200ms (+/- 5ms; can also depend on the loaded profile). As Travis said, the only alternative is fast hoping but unfortunately, I still don't have an estimation on when it will be supported...

    - Nuno Sá

  • Hello Nuno,

    When you stated the PLL port has to be moved to the calibrated state, are you referring to in_voltage0_ensm_mode?

    If not, what should I be changing when changing the LOs?


    Is it fine just to change the RX1_LO and not the others, since I am just receiving?

    As for the profile, I have set up 40M bandwidth and tried different sample rates ranging from 40.96M to 62,5M.

    Is there a profile configuration that has a 40MHz bandwidth, that would tune faster, without the hopping?

    Thanks very much

  • When you stated the PLL port has to be moved to the calibrated state, are you referring to in_voltage0_ensm_mode?

    Yes, but that is done by the driver under the hood so no need for you to do anything...

    Is it fine just to change the RX1_LO and not the others, since I am just receiving?

    That's a tricky question as LOs are not obvious. Although in theory (assuming that you are only changing RX1_LOs and no other controls) only changing RX1_LO is fine. However, If you are using a FDD profile, it's best practice that you also change RX2_LO together with RX1_LO... If you prefer not to do it, then you should move in_voltage1_ensm_mode to calibrated before starting the RX1_LOs settings.

    If the profile is TDD, for safety, you should TX1_LO to be the same as RX1_LO although this will only matter if you change a tracking calibration in RX1. Alternatively, on a TDD profile, you can just disable the TXs as you just want to receive.

    This commit description explains the reasons behind this...

    Is there a profile configuration that has a 40MHz bandwidth, that would tune faster, without the hopping?

    Don't think so...

    - Nuno Sá

  • one more question...

    Will TDD or TDM_FDD modes tune faster than FDD mode?

  • Not really sure as I never measured it. You can always try it Slight smile

    - Nuno Sá