 NapDynamite
		
			NapDynamite
		
		
		
		
		
		
		
		
	
			11-17-2015 01:33 PM
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.
11-18-2015 11:47 AM
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,
11-18-2015 08:58 PM
 rolfk
		
			rolfk
		
		
		 
		
		
		
		
		
	
			11-19-2015 03:44 AM
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.
 imim
		
			imim
		
		
		
		
		
		
		
		
	
			
			
    
	
		
		
		07-11-2019
	
		
		05:46 AM
	
	
	
	
	
	
	
	
	
	
	
	
	
	
 - last edited on 
    
	
		
		
		01-08-2025
	
		
		08:43 AM
	
	
	
	
	
	
	
	
	
	
	
	
	
	
 by 
				
		 Content Cleaner
		
			Content Cleaner
		
		
		
		
		
		
		
		
	
			
		
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.
 rolfk
		
			rolfk
		
		
		 
		
		
		
		
		
	
			07-12-2019 01:02 PM - edited 07-12-2019 01:19 PM
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.
 imim
		
			imim
		
		
		
		
		
		
		
		
	
			07-13-2019 03:30 AM - edited 07-13-2019 03:34 AM
thanks for your replay rolfk. 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/.
 rolfk
		
			rolfk
		
		
		 
		
		
		
		
		
	
			07-13-2019 04:30 AM
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?
 imim
		
			imim
		
		
		
		
		
		
		
		
	
			07-13-2019 05:32 AM - edited 07-13-2019 05:39 AM
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 rolfk.
best regards
 rolfk
		
			rolfk
		
		
		 
		
		
		
		
		
	
			07-13-2019 05:44 AM - edited 07-13-2019 06:23 AM
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.