LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

Extract j1939 Can signals with cRIO-9025 and NI9853

Hi,

Im trying to extract j1939 can signals with NI9853 module on cRIO-9025.

Most of my code are from NI example project: "CAN Signals Receive.lvproj". See attached files.

 

Communications looking good, but im only get default values from my signals i have choosen in the Xnet Create session signal list.

I have used the same j1939.dbc file with Flexlogger using NI9863 module and everything works well. At least the .dbc file looks ok.

 

I wonder if the example dosent support j1939 protocol?

If not, i would like to know how to extract signals from j1939 protocol with NI9853 module on cRIO-9025.

Thanks.

 

 

0 Kudos
Message 1 of 20
(1,522 Views)

NI-XNET supports J1939.

You can refer to the shipping example Hardware Input and Output >> CompactRIO >> Module Specific IO >> CAN >> 985x with NI-XNET to use the conversion session of XNET.

 

 

ZYOng_0-1711580690161.png

 

-------------------------------------------------------
Applications Engineer | TME Systems
https://tmesystems.net/
-------------------------------------------------------
https://github.com/ZhiYang-Ong
0 Kudos
Message 2 of 20
(1,492 Views)

Thx for your reply!,

 

Accually im refering to your code example in my first post, see attached files.

NI9853 doesnt support Xnet on FPGA side but as you mentioned i can use it on RT.

 

I successfully used the signal conversion with a CAN open protocol with your code in another project.

But when im using j1939 i only get zeroes for my extracted signals. It looks like i get the default values as output.

 

I was a bit worried that it didnt support j1939, but the extraction of signals with Xnet should all be in my added .dbc file for the signal list.

So it should work then. I have tried to log signals with my j1939.dbc file with flexlogger and i works.

 

Im a bit confused here that it still dosent work.

Im useing Labview 2019 by the way.

0 Kudos
Message 3 of 20
(1,479 Views)

Does the program work for non-J1939 frames?

Do your J1939 frames have data size greater than 8 bytes?

-------------------------------------------------------
Applications Engineer | TME Systems
https://tmesystems.net/
-------------------------------------------------------
https://github.com/ZhiYang-Ong
0 Kudos
Message 4 of 20
(1,452 Views)

My program works for CanOpen communication. But not for my j1939 signals.

Im using the same code.

 

I used Xnet database editor and find out that the payload differs depending on messages in my .dbc file

I have seen 8,12 and 16 payload lengths.

 

In my created Xnet session i have chosen signals in messages with only 8 bytes payload,

even though the .dbc file i use contains messages with longer payloads.

 

You can se one of my signals in the attachment

0 Kudos
Message 5 of 20
(1,410 Views)

I think its a bit strange that my code works for CanOpen protocol but not j1939 protocol.

 

Its state that Xnet supports j1939 from 2015.

https://knowledge.ni.com/KnowledgeArticleDetails?id=kA00Z000000kFycSAE&l=sv-SE

 

Even though i dont use Xnet module i still able to use the Xnet vi:s on my RT target with NI9853.

 

Im using an old cRIO-9025 so i dont have resources to implement NI9862 module with Xnet for my project.

Perhaps i will test NI9862 in a smaler test project just to test Xnet coding.

 

0 Kudos
Message 6 of 20
(1,380 Views)

Hi tokar,

 


@tokar wrote:

I think its a bit strange that my code works for CanOpen protocol but not j1939 protocol.


I don't have XNet installed here, so I cannot comment on the ConvertFrameRawToSignal function.

Do you really need to flatten the 6×U32 CAN data frame of the NI9853 to an array of bytes?

 

I don't have hardware with a NI9853 at hand, but worked with them for quite some time:

Can you check the ArbID in your CAN data frames for your 29bit extended ArbIDs? The NI9853 needed an additional bit set when sending extended ArbIDs (AFAIK it was bit #31 of the ArbID element) and maybe this bit is also set when receiving extended ArbIDs…

 

(How many different messages do you need to read? Wouldn't it be easier to convert the 8 byte payload using your own routine? That's what I did most of the time…)

Best regards,
GerdW


using LV2016/2019/2021 on Win10/11+cRIO, TestStand2016/2019
0 Kudos
Message 7 of 20
(1,375 Views)

Do you really need to flatten the 6×U32 CAN data frame of the NI9853 to an array of bytes?

Answer: Looking at NI example "Can signals receive.lvprog" that uses ConvertFrameRawToSignal function, they using flatten to string and convert to array of bytes. So im using the same.

 

Can you check the ArbID in your CAN data frames for your 29bit extended ArbIDs? The NI9853 needed an additional bit set when sending extended ArbIDs (AFAIK it was bit #31 of the ArbID element) and maybe this bit is also set when receiving extended ArbIDs…

Answer:My j1939 protocol using 29 bits identifier.

  In the message there is a bit that tells if its extended or not. I assumed that the Xnet function "Xnet convert(Frame raw to signal)" can handle that information, but im not sure..

Xnet supports j1939 protocol from LV2015, see link.

https://knowledge.ni.com/KnowledgeArticleDetails?id=kA00Z000000kFycSAE&l=sv-SE

 

In testing i have chosen to only use one message to extract one signal.

Its not that many signals so its possible to extract info from payload. My j1939 uses only 8 bits payloads for my wanted messages.

But i dont know how to get the separate the payload from message and nether how to convert the payload into signal values.

 Maybe you can help me with that info?

 

 

 

0 Kudos
Message 8 of 20
(1,332 Views)

Hi tokar,

 


@tokar wrote:

Its not that many signals so its possible to extract info from payload. My j1939 uses only 8 bits payloads for my wanted messages.

But i dont know how to get the separate the payload from message and nether how to convert the payload into signal values.


  • There's the SplitNumbers function to get words/bytes from longwords: it's quite easy to separate the bytes from your two U32 payload values!
  • Scaling of CAN signals is also quite easy: in your DBC you define a gain and an offset for each signal. You just need to apply them on your byte data!

You can also use TypeCast instead of those SplitNumbers functions, I use them to show the internal packing of the signals in the message…

(Edit: I built the array of bytes in the wrong order of bytes, please correct on your own.)

Best regards,
GerdW


using LV2016/2019/2021 on Win10/11+cRIO, TestStand2016/2019
0 Kudos
Message 9 of 20
(1,325 Views)

I think GredW is correct. If I remember correctly, NI-985x handles ArbID slightly differently than NI-XNET. There is an extension ID flag.

Can you save your raw J1939 data from NI-985s on a control in a VI and post it here? I don't have an NI-985x but I can play around with NI-XNET.

-------------------------------------------------------
Applications Engineer | TME Systems
https://tmesystems.net/
-------------------------------------------------------
https://github.com/ZhiYang-Ong
0 Kudos
Message 10 of 20
(1,317 Views)