Function
Retrieves the transfer position on sampling buffer.
Format
Ret = CntGetSamplingWritePointer ( Id , WritePointer , ScanCount , ScanCarry )
Parameters
Id
[ C, C++ : short ] [ Python: ctypes.c_short ]
Specifies the device ID retrieved from CntInit.
WritePointer
[ C, C++ : int * ] [ Python: ctypes.POINTER(ctypes.c_int) ]
Specify the address of the variable that stores the returned transfer position.
ScanCount
[ C, C++ : int * ] [ Python: ctypes.POINTER(ctypes.c_int) ]
Specify the address of the variable that stores the scan count.
ScanCarry
[ C, C++ : int * ] [ Python: ctypes.POINTER(ctypes.c_int) ]
Specify the address of the variable that stores the carry count.
Return Value
Ret [ C, C++ : long ] [ Python: ctypes.c_long ]
Definition |
Value |
Description |
CNT_ERR_SUCCESS |
0 |
Normal Complete |
CNT_ERR_DLL_INVALID_ID |
10001 |
Invalid ID is specified. |
CNT_ERR_DLL_CALL_DRIVER |
10002 |
Driver cannot be called (failed in ioctl). |
CNT_ERR_DLL_BUFF_ADDRESS |
10101 |
Invalid data buffer address. |
CNT_ERR_SYS_MEMORY |
20000 |
It failed in memory allocation for the object preparation. |
CNT_ERR_SYS_USING_OTHER_PROCESS |
20003 |
Cannot use because another process is using the device. |
The other errors: (See also: Details of Error Code)
Initial Value
None
Remarks
You can know the position
where the data is written on the sampling buffer.
When both transfer count number and transfer position are 0, it indicates
the state that no data are transferred, therefore, the actual written
position is the previous value of the transfer count number retrieved
by this function.
And, the sampling count
is a 64-bit counter.
You can calculate 64bit value from ScanCount (Second argument) and ScanCarry
(Third argument).
ScanCarry is the higher 32-bit, ScanCount is the lower 32-bit.
After starting count,
the sampling number will be put into ScanCount.
ScanCarry will be increased (+1) and ScanCount is preset to zero(0) when
ScanCount is overflowed.
WritePointer, ScanCount
and ScanCarry are reset when you call CntResetDevice
or CntSamplingStart.
These are not reset when you call CntInit.
Example
C, C++ |
Ret
= CntGetSamplingWritePointer (Id, &WritePointer, &ScanCount,
&ScanCarry); |
Python |
Ret
= ccnt.CntGetSamplingWritePointer (Id, ctypes.byref(WritePointer),
ctypes.byref(ScanCount), ctypes.byref(ScanCarry)) |