The SmartcardT1Request function copies data from the user buffer to a send buffer and checks the T=1 protocol status.
NTSTATUS
SmartcardT1Request(
PSMARTCARD_EXTENSION SmartcardExtension
);
SmartcardT1Request returns an NTSTATUS value. Possible values are the following.
Value | Meaning |
---|---|
STATUS_SUCCESS | Buffer successfully set up. |
Do not change any members of the T1_DATA structure. They will be initialized automatically. The only member that can be safely modified is the NAD value. Changing any member might lead to protocol errors.
SmartcardT1Request copies the data from the user buffer to SmartcardExtension->SmartcardRequest.Buffer embedded in a T=1 protocol frame and adjusts SmartcardExtension->SmartcardRequest.BufferLength. The driver must send this buffer to the smart card and read the answer of the card into SmartcardExtension->SmartcardReply.Buffer. The driver must then call SmartcardT1Reply (VxD), which checks the incoming protocol frame.
You can copy your header data to the buffer either before or after a call to SmartcardT1Request, depending on which is easier to do in your driver. If your driver needs to send header data to the reader before the actual T=1 data, you should set SmartcardExtension->SmartcardRequest.BufferLength to the number of bytes you need for your header before you call this function. The packet will look like this:
A usual T=1 transmission can be done in the following way:
// Run this loop as long as the protocol requires to send data
do {
// Copy data to SmartcardExtension->SmartcardRequest.Buffer
// embedded in a T=1 frame
status = SmartcardT1Request(SmartcardExtension);
if (status != STATUS_SUCCESS)
return status;
// Send T=1 frame to smart card
status = DriverSendDataToSmartcard(…);
if (status != STATUS_SUCCESS)
return status;
// Now set appropiate timeout (This example calculates. the time-out in ms)
// Timeout = SmartcardExtension->CardCapabilities.T1.BWT *
// (SmartcardExtension->T1.Wtx ? SmartcardExtension->T1.Wtx : 1);
// receive T=1 frame from smart card
status = DriverReceiveDataFromSmartcard(…);
if (status != STATUS_SUCCESS)
return status;
// Check T=1 protocol status and copy any data back to user buffer
status = SmartcardT1Reply(SmartcardExtension);
} while (status == STATUS_MORE_PROCESSING_REQUIRED);
return status;
SmartcardT1Request functions the same for WDM and VxD drivers.