This thread has been locked.

If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.

LMK04821: how to synchronize two lines of output clock

Part Number: LMK04821
Other Parts Discussed in Thread: CODELOADER

   I am using two-channel clock SDCLKout7 and SDCLKout11 to output 2GHz clock. I need to synchronize the two outputs according to the description in the manual, as shown below:


What do I need to do to fulfill my requirements? Does the manual describe how to modify the corresponding value during the configuration from 0x000 to 0x1FFF (my configuration sequence is generated by the software), or do I need to configure the data after or before the configuration? I'm sorry that I didn't fully understand the meaning of the example. I would appreciate it if you could help me elaborate

  • Hi,

    For the sync output, you need to follow the SYNC procedure mentioned below:

    If you wants to operate at 2GHz at SDCLKout7 and SDCLKout11, this frequency will be directly from VCO (without channel dividers) and should be synchronized to each other. It needs to be configured SDCLKout7 and SDCLKout11 with device clock out.

    You can use the TICS Pro tool to configure the device.

    Thanks!

    Regards,

    Ajeet Pal

  • Hi,

    Thank you for your reply and answer above, but I want to know at which stage the status bits I need to modify are carried out. It seems that the sequence generated by the software does not contain the status bits mentioned above. Since I am not a hardware engineer, I do not quite understand the use of your software. I hope you can give me more information to answer my doubts.

    Thanks!

    Regards,

    ShuJie

  • Hi Ajeet, 

    I want to add some info here for this case, actually the key question is that:

    How to complete the following specific register in the FPGA code? Since the register 0x0000 to 0x1fff is generated by our tics or codeloader directly. Should we place the following setup before generated register loading or after the register loading.

    And how to change the specific register status in their code, such as SYSREF_CLR.

    Thanks

    Best regards

    Mia Ma

  • Hi Mia, ShuJie,

    For the programming, you should first program all registers as mentioned in "Recommended Programming Sequence" section then for SYNC and /or SYSREF operation, you can go required registers update mentioned for each example.

    For individual bits update, need to write particular address register with the bit update, like for SYSREF_CLR, you need to write x143 register with [7] bit update.

    I hope, it clarifies your question. 

    Thanks!

    Regards,

    Ajeet Pal

  • As I understand it, I set 0x140 to 0x00 and 0x143 to 0x91, based on the following picture:


    My combination is Differential input SYNC, so I didn't care about SYSREF_MUX and SYNC_MODE status, but that didn't work out as I expected, did I have a configuration error?
    According to the screenshot below:


    I checked the registers that need to be configured one by one, except the above two, the others have been configured to the expected values when the software was generated, so I didn't modify them. In addition, since I need to synchronize the same clock frequency, I'm too sure how many bits SYSREF_PULSE_CNT need to be configured, please give me some technical guidance.
    My register sequence is as follows:

    R0 (INIT) 0x000090
    R0 0x000010
    R2 0x000200
    R256 0x010000
    R257 0x010155
    R259 0x010345
    R260 0x010402
    R261 0x010500
    R262 0x0106F0
    R263 0x010733
    R264 0x010810
    R265 0x010955
    R267 0x010B45
    R268 0x010C02
    R269 0x010D10
    R270 0x010EF0
    R271 0x010F01
    R272 0x01100A
    R273 0x011155
    R275 0x011347
    R276 0x011402
    R277 0x011500
    R278 0x0116F0
    R279 0x011701
    R280 0x011801
    R281 0x011955
    R283 0x011B45
    R284 0x011C22
    R285 0x011D06
    R286 0x011EF0
    R287 0x011F16
    R288 0x012008
    R289 0x012155
    R291 0x012300
    R292 0x012402
    R293 0x012500
    R294 0x0126F8
    R295 0x012700
    R296 0x012801
    R297 0x012955
    R299 0x012B45
    R300 0x012C22
    R301 0x012D00
    R302 0x012EF0
    R303 0x012F16
    R304 0x013019
    R305 0x013155
    R307 0x013345
    R308 0x013402
    R309 0x013500
    R310 0x0136F0
    R311 0x013733
    R312 0x013805
    R313 0x013905
    R314 0x013A1F
    R315 0x013BFF
    R316 0x013C00
    R317 0x013D08
    R318 0x013E03
    R319 0x013F00
    R320 0x01400A
    R321 0x014100
    R322 0x014200
    R323 0x014310
    R324 0x01447F
    R325 0x01457F
    R326 0x014618
    R327 0x014718
    R328 0x014802
    R329 0x014942
    R330 0x014A02
    R331 0x014B16
    R332 0x014C00
    R333 0x014D00
    R334 0x014EC0
    R335 0x014F7F
    R336 0x015003
    R337 0x015102
    R338 0x015200
    R339 0x015300
    R340 0x015478
    R341 0x015500
    R342 0x015678
    R343 0x015700
    R344 0x015896
    R345 0x015900
    R346 0x015A78
    R347 0x015BD4
    R348 0x015C20
    R349 0x015D00
    R350 0x015E00
    R351 0x015F0B
    R352 0x016000
    R353 0x016101
    R354 0x016200
    R355 0x016300
    R356 0x016400
    R357 0x016519
    R372 0x017405
    R380 0x017C15
    R381 0x017D33
    R358 0x016600
    R359 0x016700
    R360 0x016819
    R361 0x016951
    R362 0x016A20
    R363 0x016B00
    R364 0x016C00
    R365 0x016D00
    R366 0x016E13
    R371 0x017300
    R8189 0x1FFD00
    R8190 0x1FFE00
    R8191 0x1FFF53

    Thanks!

    Regards,

    ShuJie

  • Hi ShuJie,

    For differential SYNC input at CLKin0, you doesn't necessary bother about SYNC_MODE and SYSREF_MUX settings. CLKin0 direct feed to SYSREF_CLKin0_MUX and set for "From CLKin0" and can synchronize the device with this. To reset the required channel dividers set SYNC_DISx and SYNC_DISSYSREF bits to 0 and input the SYNC. Once dividers are reset, change SYNC_DISx and SYNC_DISSYSREF bits to 1. 

    Then if you wants to set the SYSREF outputs in pulsar mode, follow the below sequence:

    0x139 --> 0x02

    0x143 --> 0x13

    For sending the SYSREF pulses through SPI at desired SDCLKoutx channel, write 0x13E --> 0x03.

    Hope, it clarifies your queries.

    Thanks!

    Regards,

    Ajeet Pal