08-21-2009 05:51 PM
Hi, all--I am pretty much a LabVIEW beginner, but starting to dry a little behind the ears. Currently working on a project where the original LV code called VC CINs. We want to convert the CINs (lvsbutil.exe--ick) to Call Library Function nodes and so I am working to convert the CIN code to a DLL. Finally got everything compiled happily and went to run my VI calling the DLL--as far as I could tell, at the DLL call, CRASH! So then, I fiddle around making a CVI main that I can use to call my crashing DLL(debug mode) from and I find the crash happens when I call FRefNumToFD, even though the RefNum seems to be legit. I even tried inserting FIsARefNum in front of the conversion routine, and FIsARefNum crashes now too. Is there a problem with these file manager functions? Is there something freaky with RefNum passing between CVI and LV?
I am using CVI 9.0 and LV 2009. Thanks for all input!
08-22-2009 09:09 AM
08-23-2009 02:51 PM
ctakac wrote:Hi, all--I am pretty much a LabVIEW beginner, but starting to dry a little behind the ears. Currently working on a project where the original LV code called VC CINs. We want to convert the CINs (lvsbutil.exe--ick) to Call Library Function nodes and so I am working to convert the CIN code to a DLL. Finally got everything compiled happily and went to run my VI calling the DLL--as far as I could tell, at the DLL call, CRASH! So then, I fiddle around making a CVI main that I can use to call my crashing DLL(debug mode) from and I find the crash happens when I call FRefNumToFD, even though the RefNum seems to be legit. I even tried inserting FIsARefNum in front of the conversion routine, and FIsARefNum crashes now too. Is there a problem with these file manager functions? Is there something freaky with RefNum passing between CVI and LV?
I am using CVI 9.0 and LV 2009. Thanks for all input!
You cannot call FRefNumToFD outside LabVIEW. In fact you can only link such a DLL when youlink in labview.lib and once you do that you can only run this DLL from within LabVIEW. So your C test program in CVI is in fact useless. Well I'm even surprised that you can run your CVI test program without getting a message box telling you that the DLL can only be executed from within a LabVIEW process.
A CVI file refnum is absolutely not the same as a LabVIEW FileRefnum. If you call your DLL from LabVIEW, passing it a file refnum then you have to use all LabVIEW file manager functions to operate on them. And that means you can only run and test your DLL from within LabVIEW.
Rolf Kalbermatter
08-24-2009 10:25 AM
08-24-2009 10:55 AM
Hi, smercurio--
My refnum is created in LabVIEW. That method worked fine when it was a CIN I was dealing with.....It's not a hard crash I'm getting, more like a soft one, where the code goes off into la-la land but does not kill the PC.
08-24-2009 10:59 AM
Hi, rolf--
I was trying to use all LV file manager functions in my DLL, hence FRefNumToFD! But, you confirmed my suspicion that the LV RefNum isn't understood within CVI, even if you're using the LV file manager functions.
08-24-2009 11:06 AM
No, if you pass a file refnum (stream file refnum, yes????) from a LabVIEW diagram into a DLL and call LabVIEW manager functions it should work. You do link with LabVIEW.lib do you?
Rolf Kalbermatter
08-24-2009 11:11 AM
OK: here is a screen shot of my vi, and some of the code from my CVI dll--
//#include "extcode.h"
#include "ShareLib_ProcessEF.h" //The commented out stuff is in this header file
.
.
.
/*typedef struct
{
int32_t dimSize;
uint16_t elt[1];
} TD1;
typedef TD1 **TD1Hdl; */
#define CHECKSUM ChecksumNew
extern void CHECKSUM (uInt8 *pData, int32 Size, uInt16 *pXOR, uInt16 *pChk_sum);
uInt8 **hRead_buf;
int32 __declspec(dllexport)ProcessEFBlock(LVRefNum *hFile, uint16_t *pChksum, uint16_t *pXOR, TD1Hdl hData_block,
TD1Hdl hHdr_block, LVBoolean *pEOF, LVBoolean *pDLOK, LVBoolean *pSEND);
int32 __declspec(dllexport)ProcessEFBlock(LVRefNum *hFile, uint16_t *pChksum, uint16_t *pXOR, TD1Hdl hData_block,
TD1Hdl hHdr_block, LVBoolean *pEOF, LVBoolean *pDLOK, LVBoolean *pSEND)
{
MgErr mgError;
File fd;
int32 byte_count;
uInt8 size_buffer[2];
int32 read_buf_size;
int32 offset;
uInt8 *pRead_buf;
uInt16 *pData_buf;
uInt16 tmpChksum;
int32 i;
uInt16 fill_count;
int32 DataBlockSize;
uInt8 **hTemp_buf;
uInt8 *pTemp_buf;
uInt8 fill_byte;
BYTEWORD byteword;
BYTELONG bytelong;
Bool32 iRefNumErr;
mgError = 0;
// Convert file reference to file descriptor
iRefNumErr = FIsARefNum(*hFile); //This is where the code leaves to think things over
if (mgError = (FRefNumToFD (*hFile, &fd)))
{
goto out;
} // if
08-24-2009 11:13 AM
08-25-2009 06:17 PM