LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

Desktop RT target with USB camera support

Hi,

 

I am converting a desktop PC into an RT target to deploy vision system for inspection. I'm just protyping my design and to have Real-Time control I have opted for this approach. My question is, can I use Vision modules with USB camera support inside the RT target?. The desktop PC has four USB ports and it should have required vision software installed inside. Can someone guide on the approach and walk me through the procedure of installing vision modules inside RT target so I could use Vision acquisition and Development modules and deploy entire system inside the RT target.

 

The part "I/O control" comes next defnintely by using PCI cards. 

 

 

 

Regards. 


0 Kudos
Message 1 of 10
(5,272 Views)

Hello NapDynamite,

 

Sadly, the RT Desktop PC runs the Phar Lap operating systems.  Currently, there are no USB 2.0 or 3.0 drivers available for vision on Phar Lap.  You will need to use CameraLink or GiGE cameras.

 

Regards,

 

Thomas C.
FlexRIO Product Support Engineer
National Instruments
0 Kudos
Message 2 of 10
(5,243 Views)
I'm running LabVIEW RT inside desktop. What OS is it running on? Vxworks or PharLab? Because if sbRIOs and cRIOs are running LVRT, they do have a USB port and support USB camera. I may be wrong which is why I'm here seeking assistance.

0 Kudos
Message 3 of 10
(5,224 Views)

LabVIEW RT on a desktop is always running on Pharlap ETS. LabVIEW RT on a cRIO is running on either Pharlap ETS, VxWorks, or NI Linux RT depending on the hardware model of the RIO hardware. If it is old and has a x86 compatible CPU it generally runs Pharlap ETS. If it has a Power PC CPU it runs VxWorks and if it is based on the Zync embedded ARM CPU or is one of the modern x86 targets it runs NI Linux RT either for ARM or x64.

 

Generally driver support for other than NI hardware on the Pharlap and VxWorks based targets is non-existent. For NI Linux RT based targets you can definitely get almost every driver to work if you have the driver source code available for a fairly recent Linux system. Developing an USB camera driver for Pharlap or VxWorks would be a very huge effort and there aren't any readily available anywhere, not even for a lot of money.

 

Rolf Kalbermatter  My Blog
DEMO, Electronic and Mechanical Support department, room 36.LB00.390
Message 4 of 10
(5,207 Views)

what about Desktop RT target with pci device support ?  this  https://knowledge.ni.com/KnowledgeArticleDetails?id=kA03q000000x3gICAQ&l=en-US  link say that Developers who write Real-Time driver code for third-partyPXI, CompactPCI (cPCI) and PCI devices can access the control/status registers (CSRs) and shared memory through a common PCI programming interface provided by NI-VISA.so i follow https://knowledge.ni.com/KnowledgeArticleDetails?id=kA03q000000x3gICAQ&l=en-US to step 7 and i see my pci card in ni max on pharlap but i cant read /write data.what must i do?
thank you.

0 Kudos
Message 5 of 10
(4,181 Views)

Well if you get to step 7 in that tutorial and see the card in NI-Max the VISA driver should be ok. Now comes the real fun part. Do you have a register description of your PCI device? Basically your PCI device has a certain number of basic registers as mandated by the PCI standard for Plug and Play configuration and then it has another set of registers that are entirely proprietary to what it implements. There is no further standard in what a PCI device has to provide, in the most simple case it only supports a few extra registers that let you configure some functionality and read and write some data to it. In the worst case it contains a myriad of registers that control just about anything imaginable and some shared memory interface to transfer data to and from it.

 

What of all that and how is defined in the register description of your device which you must have available of course. For many devices however this type of information is considered top secret trade secret and gets guarded with not only an absence of any available documentation but also with involvment of a legal departement that is determined to suffocate any attempt to get such information out there right in the earliest possible stages.

 

Assuming you have a proper documentation of your PCI device register map you would start using the VISA->Register Access functionality in LabVIEW. Expect to forget about anything you have learned so far about communicating with devices. This is not about sending a SCPI formatted string command of type ::DATA:ACQ? to the device but about setting the bit x in register 0x2345 to TRUE after you properly wrote address 0xZZZZZZZZ into device register 0x1234 together with a few dozen other bit manipulations in different other registers and the amount of data to transfer in register 0x3456. Repeat and rinse for every other operation you want to do on your PCI device. Also expect the register map description to assume that any reader of it knows the device already intimately and has a very good low level understanding about interrupt handling, DMA transfers and how the various bits and bytes in all the registers are supposed to work together.

 

VISA makes most of this available without any need to dive into kernel device driver programming in C or assembly code but it can not take away the inherent complexity of such a low level device interface.

Rolf Kalbermatter  My Blog
DEMO, Electronic and Mechanical Support department, room 36.LB00.390
0 Kudos
Message 6 of 10
(4,165 Views)

thanks for your replay . We design a PCI card with VHDL wishbone PCI core of opencores site. We define two register in VHDL top level code. Our registers is defined on 0x180_0000 and 0x180_0004 addresses of PCI address/data bus. 0x180_0000 is read only and 0x180_0004 is read and write register. TEMP(7 DOWNTO 0)<=WB_DOUT(7 downto 0) when WB_STB='1' and WB_WE='1' and WB_ADDR(24 downto 5)="11000000000000000000"; T1<=WB_DOUT(15 downto 0) when WB_STB='1' and WB_WE='1' and WB_ADDR(24 downto 2)="11000000000000000000001"; WB_DIN<=X"BBAA" when WB_ADDR(24 downto 2)=="11000000000000000000000" else T1 when WB_STB='1' and WB_WE='0' and WB_ADDR(24 downto 2)="11000000000000000000001";
I attach some photo for more information about our works and also please see https://lavag.org/topic/21061-labview-realtime-pharlap-os/.

 

0 Kudos
Message 7 of 10
(4,142 Views)

Well I never did this but it would seem that you are almost there. Now you need to create a LabVIEW project and add that target to it. In there you should be able to open a VISA resource to your board using the PXI::.... resource identifier and then using the low level VISA functions to read and write the registers.  Have you tried that?

Rolf Kalbermatter  My Blog
DEMO, Electronic and Mechanical Support department, room 36.LB00.390
0 Kudos
Message 8 of 10
(4,129 Views)

yes i tried that and labview has not returned me any errors. in test number one attach file "back1.png" i test manufacture id and bar0 address base and returned value is true.but in test number two attach file "back2.png" when i read address bar0 with offset 0x1800000 i get ffff value and it is false value. based on my fpga program it must be "BBAA" value. do you have any idea for this?
also i attach my labview project in pcitest.vi.

thank you for the time you spend .

best regards

0 Kudos
Message 9 of 10
(4,123 Views)

I’m just guessing here but have you tried to read address 0x0000 instead. The address you show llooks like an absolute linear address as how the PCI resource was mapped into your system but it will of course change if the board is placed in a different slot. Accordingly you do not want this variation in a driver but instead only want to use the offset to the register map base in your driver. I’m convinced VISA will add that offset to the base address as assigned by the PCI enumerator.

 

This post here seems to be relevant to your problem although not a complete solution.

Rolf Kalbermatter  My Blog
DEMO, Electronic and Mechanical Support department, room 36.LB00.390
0 Kudos
Message 10 of 10
(4,114 Views)