Real-Time Measurement and Control

cancel
Showing results for 
Search instead for 
Did you mean: 

cRIO 9053 and NTP client

Hi all guys,

I need to syncronyze the time of Crio with the time of a PC connected in the same local network.

I follow this paper: https://knowledge.ni.com/KnowledgeArticleDetails?id=kA03q000000YIF2CAO&l=it-IT

The NTP server and client are running well.

I just have one question: how do I force the time update on the crio? I searched for ntpq commands but no solution. Do you have any advice?

(No TSN-enabled targets on the system).

Thanks!

0 Kudos
Message 1 of 11
(723 Views)

Hi danieletime,

 

as far as I know, there is no command to synchronize the time in one step. When the NTP daemon runs, it synchronizes the system time slowly in very little steps. But when you shut down the system (or restart it), it should set the system time directly to the actual time.

 

You can check the offset to a time-server with the command `ntpq -p`.

 

0 Kudos
Message 2 of 11
(689 Views)

Thanks for the reply Manuel,

What do you mean by "actual time"? When I restart the crio nothing happens, it seems to never synchronize the time with the NTP server.

In the attachment: the "ntpq -pn" reply and "/etc/ntp.conf" file.

 

 

0 Kudos
Message 3 of 11
(680 Views)

It looks from the ntpq response that the network connection to your NTP server has been interrupted at some point (AFAIK .XFAC. means interface association change).

 

Have you tried restarting ntpd after all the network interfaces have been fully configured, DHCP completed etc?

 

 

/etc/init.d/ntpd restart

 

 

Also have you checked that you can access your NTP server (e.g. via ping if it is configured to respond to ping).  It seems like you are using an NTP server on a local LAN - what is it synchronised to?  Note if it is not trusted (stratum is too high) you may struggle to get it to sync.  Also you may find the first time it takes a long time to sync (although once it has synced once it is usually much faster subsequently).

 

 

0 Kudos
Message 4 of 11
(672 Views)

Thanks AaronL,

I don't know why, but doesn't work. I tried the ntpdate instead ntpq, and the syncronization working well when I lanch the "ntpdate 192.168.10.3" command. But within a few seconds the offset continues to grow, until it reaches 2.796 seconds. See screenshot. Why? This really disturbs me!

0 Kudos
Message 5 of 11
(664 Views)

Hi,

 

The first thing I'd like to say is that it's a shame that the time can't be set effectively on the Linux RT target, and that the only way to do this is to use NI MAX or the "Set time" function from the System Configuration, which is slow, memory-consuming and easily produces errors of up to 3 seconds. In the video from 2019 (https://www.ni.com/en/shop/compactrio/compactrio-timing-and-synchronization.html) I learned that "some functions are not ready for Linux RT targets, but this will be fixed very soon". Today is the fall of 2024.

 

Time synchronisation is generally poorly documented and pretty much does not work, even if everything is done according to the manuals. There are actually a number of manuals on the same subject (how to set up time synchronisation on the Linux RT cRIOs), but none of them are complete, they are missing important information, they contradict each other in some places (especially suggested configs), or they are just plain wrong. I've spent a lot of time on this this week and still can't get it to work. Maybe it is just me.

 

Anyway, my findings are below (cRIO 9053 and a struggle to synchronise the time with the PC).

Disposition:

  • Compact RIO NI 9053, Linux RT 2024 Q3 (latest as of today).
  • Connected to a Windows PC via USB-network cable (console port), i.e. PC is 172.22.11.1 and cRIO is 172.22.11.2.
  • All the required firewall ports are open for anyone (confirmed with the NTP client on other computer).

 

What I tried/found:

  1. Followed the same manual as you have used, https://knowledge.ni.com/KnowledgeArticleDetails?id=kA03q000000YIF2CAO&l=fi-FI There are funny thing about it, is that it is suggests that the cRIO has access to the Internet, which is not always true or easy to achieve, but whatever. While this manual tells, that "To use NTP with TSN-enabled targets, such as the cRIO-904x and 905x, the Linux OS time needs to be desynchronized with the network time." and even provides the how-to instruction (https://www.ni.com/en/support/documentation/supplemental/21/use-ntp-for-timestamping-measurements.ht...), this instruction does not explain, should this be done only when I want to use 802.1AS, or it is valid for 1588 as well? (hint: none of the four combinations do not work).
  2. Important part, "How do I configure my host computer as NTP Time Server" (https://knowledge.ni.com/KnowledgeArticleDetails?id=kA03q000000YIeDCAW&l=fi-FI) tells us, that the Windows time server is no-no. Well, it would be great to see the mention about that in all the other manuals, including the first one. And, anyways, while I was able to at least connect to the Windows time server in #1, the recommended setup of the Meinberg NTP is not working at all. 
  3. Older manual https://forums.ni.com/t5/Example-Code/Installing-and-Configuring-NTP-on-NI-Linux-Real-Time-Devices/t... does not work either. 
  4. This is more related to the synchronization of the multiple cRIOs (or equivalent) between each other, but still. The manual "Monitor and Configure Time Synchronization on Embedded Devices"  (https://www.ni.com/en/support/documentation/supplemental/17/monitor-and-configure-time-synchronizati...) tells that the time references must be selected to drive the time of the device. There is a related manual on that, but it is only valid for the NI-Sync version 18.0 or earlier. What the users of the newer versions should be doing - big mystery.
  5. Additionally, the example "Monitor and Configure Time References" shows that in 1588 mode the clock state is always "Faulty" (regardless Master/Slave configuration) and in the 802.1AS mode the clock state is always "Disabled", not AS capable and not selected. I can't find any explanations anywhere, how to read and understand these values.
  6. Interestingly, that with the theoretically incompatible Windows time server I was able to set a proper connection to NTP and get the quite accurate offset between the PC and cRIO (as far as I was able to check, better than 50 ms). The problem is, that even if the offset is known, cRIO for some reason does not correct it's own internal clock time. In the ntpd.log I see something like, but that's it:
    19 Sep 10:43:53 ntpd[1635]: Listen and drop on 0 v6wildcard [::]:123
    19 Sep 10:43:53 ntpd[1635]: Listen and drop on 1 v4wildcard 0.0.0.0:123
    19 Sep 10:43:53 ntpd[1635]: Listen normally on 2 lo 127.0.0.1:123
    19 Sep 10:43:53 ntpd[1635]: Listen normally on 3 lo [::1]:123
    19 Sep 10:43:53 ntpd[1635]: Listen normally on 4 usb0 [fe80::280:2fff:fe36:94df%3]:123
    19 Sep 10:43:53 ntpd[1635]: Listening on routing socket on fd #21 for interface updates
    19 Sep 10:43:53 ntpd[1635]: kernel reports TIME_ERROR: 0x41: Clock Unsynchronized
    19 Sep 10:43:53 ntpd[1635]: kernel reports TIME_ERROR: 0x41: Clock Unsynchronized
    19 Sep 10:43:57 ntpd[1635]: Listen normally on 5 usb0 172.22.11.2:123

  7. Also I was able to synchronize with the local NTP on the Linux machine on the same network, but the outcome the same as I can see with Windows time: the offset calculated correctly, but local time is not corrected. 
  8. Oh yes, and this document https://knowledge.ni.com/KnowledgeArticleDetails?id=kA00Z0000019XmjSAE&l=fi-FI says that "TSN-enabled targets (such as cRIO-904x targets) are not currently compatible with any type of synchronization besides IEEE-1588 (PTP) and 802.1AS synchronization." For me currently it reads like "TSN-enabled targets (such as cRIO-904x targets) are not currently compatible with any type of synchronization".

After all, the promised sync quality of 1 ms or even 1 us at the moment looks like a bad "up to" advertisment (https://www.ni.com/en/shop/compactrio/choosing-a-compactrio-synchronization-technology.html), because right now I see a nearly 2 seconds offset.

 

I would really appreciate if someone can provide the working step-by-step instruction for the TSN-enabled Linux RT target, connected via [USB-]network to the Windows PC.

 

P.S. Sorry for rant.

0 Kudos
Message 6 of 11
(496 Views)

I was struggling with this as well and having the same issues. I fixed the issue by adding a line of code after the server IP address in the config file. The line is fudge <Ip address> stratum 14

So it worked for me after following these instructions and adding this line of code:

 

jwright30_0-1734426838446.png

jwright30_1-1734426893041.png

 

 

 

0 Kudos
Message 7 of 11
(125 Views)

Thank you. Have you checked that the LabVIEW code returns the correct time? Because what I had, in some attempts I was lucky to get the ntpd apparently working and pretending to be synchronised, but when the time was pulled via the LabVIEW code, it turned out that it still was not in sync.

0 Kudos
Message 8 of 11
(104 Views)

You're right. The time isn't actually getting updated. I had to stop ntpd and do ntpdate <ipaddress> to update the time. 

0 Kudos
Message 9 of 11
(87 Views)

So I am able to update the time using ntpdate over ssh putty, but when I tried to do it over labview I had an issue of permission denied since I need to have root access to use ntpdate. I followed the below link to try to do this:

https://blog.sasworkshops.com/crio-tips-running-linux-command-as-root-from-labview/

but now it is saying "sudo: ntpdate: command not found"

 

this has been a frustrating issue so far, any ideas?

0 Kudos
Message 10 of 11
(67 Views)