40 #include <sys/types.h> 66 LONG EHRegisterClientForEvent(int32_t filedes)
106 Log2(PCSC_LOG_ERROR,
"Can't remove client: %d", filedes);
133 LONG EHInitializeEventStructures(
void)
148 LONG EHDeinitializeEventStructures(
void)
164 Log1(PCSC_LOG_INFO,
"Thread already stomped.");
173 Log1(PCSC_LOG_INFO,
"Stomping thread.");
176 dwGetSize =
sizeof(ucGetData);
178 &dwGetSize, ucGetData);
180 #ifdef HAVE_PTHREAD_CANCEL 181 if ((
IFD_SUCCESS == rv) && (1 == dwGetSize) && ucGetData[0])
183 Log1(PCSC_LOG_INFO,
"Killing polling thread");
184 (void)pthread_cancel(rContext->
pthThread);
190 RESPONSECODE (*fct)(DWORD) = NULL;
192 dwGetSize =
sizeof(fct);
194 &dwGetSize, (PUCHAR)&fct);
196 if ((
IFD_SUCCESS == rv) && (dwGetSize ==
sizeof(fct)))
198 Log1(PCSC_LOG_INFO,
"Request stopping of polling thread");
202 Log1(PCSC_LOG_INFO,
"Waiting polling thread");
206 rv = pthread_join(rContext->
pthThread, NULL);
208 Log2(PCSC_LOG_ERROR,
"pthread_join failed: %s", strerror(rv));
213 Log1(PCSC_LOG_INFO,
"Thread stomped.");
226 Log2(PCSC_LOG_ERROR,
"Initial Check Failed on %s",
231 rv = ThreadCreate(&rContext->
pthThread, 0,
232 (PCSCLITE_THREAD_FUNCTION( ))EHStatusHandlerThread, (LPVOID) rContext);
235 Log2(PCSC_LOG_ERROR,
"ThreadCreate failed: %s", strerror(rv));
246 const char *readerName;
249 uint32_t readerState;
250 int32_t readerSharing;
251 DWORD dwCurrentState;
252 #ifndef DISABLE_AUTO_POWER_ON 269 #ifdef DISABLE_AUTO_POWER_ON 273 Log1(PCSC_LOG_INFO,
"Skip card power on");
287 Log1(PCSC_LOG_DEBUG,
"powerState: POWER_STATE_POWERED");
291 LogXxd(PCSC_LOG_INFO,
"Card ATR: ",
296 Log1(PCSC_LOG_INFO,
"Card ATR: (NULL)");
302 Log1(PCSC_LOG_DEBUG,
"powerState: POWER_STATE_UNPOWERED");
303 Log3(PCSC_LOG_ERROR,
"Error powering up card: %ld 0x%04lX", rv, rv);
334 Log2(PCSC_LOG_ERROR,
"Error communicating to: %s", readerName);
356 Log2(PCSC_LOG_INFO,
"Card Removed From %s", readerName);
380 #ifdef DISABLE_AUTO_POWER_ON 385 Log1(PCSC_LOG_DEBUG,
"powerState: POWER_STATE_UNPOWERED");
387 Log1(PCSC_LOG_INFO,
"Skip card power on");
404 Log1(PCSC_LOG_DEBUG,
"powerState: POWER_STATE_POWERED");
410 Log1(PCSC_LOG_DEBUG,
"powerState: POWER_STATE_UNPOWERED");
421 Log2(PCSC_LOG_INFO,
"Card inserted into %s", readerName);
429 LogXxd(PCSC_LOG_INFO,
"Card ATR: ",
434 Log1(PCSC_LOG_INFO,
"Card ATR: (NULL)");
437 Log1(PCSC_LOG_ERROR,
"Error powering up card.");
444 if (readerSharing != rContext->
contexts)
456 #ifndef DISABLE_ON_DEMAND_POWER_ON 472 #ifndef DISABLE_ON_DEMAND_POWER_ON 480 Log1(PCSC_LOG_DEBUG,
"powerState: POWER_STATE_UNPOWERED");
492 Log1(PCSC_LOG_DEBUG,
"powerState: POWER_STATE_POWERED");
497 if (rContext->
hLockId == 0xFFFF)
502 Log1(PCSC_LOG_INFO,
"Die");
504 (void)pthread_exit(NULL);
LONG EHUnregisterClientForEvent(int32_t filedes)
Unregister a client and log an error if the client is not found.
LONG IFDStatusICC(READER_CONTEXT *rContext, PDWORD pdwStatus)
Provide statistical information about the IFD and ICC including insertions, atr, powering status/etc...
This abstracts dynamic library loading functions.
struct pubReaderStatesList * readerState
link to the reader state
uint32_t cardAtrLength
ATR length.
int32_t contexts
Number of open contexts.
volatile SCARDHANDLE hLockId
Lock Id.
#define TAG_IFD_STOP_POLLING_THREAD
method used to stop the polling thread (instead of just pthread_kill())
#define SCARD_S_SUCCESS
No error was encountered.
void EHSignalEventToClients(void)
Sends an asynchronous event to any waiting client.
pthread_t pthThread
Event polling thread.
LONG IFDGetCapabilities(READER_CONTEXT *rContext, DWORD dwTag, PDWORD pdwLength, PUCHAR pucValue)
Get's capabilities in the reader.
#define SCARD_UNKNOWN
Unknown state.
RESPONSECODE(* pthCardEvent)(DWORD, int)
Card Event sync.
char readerName[MAX_READERNAME]
reader name
int32_t readerSharing
PCSCLITE_SHARING_* sharing status.
This handles protocol defaults, PTS, etc.
This handles abstract system level calls.
int slot
Current Reader Slot.
uint32_t eventCounter
number of card events
This wraps the dynamic ifdhandler functions.
This demarshalls functions over the message queue and keeps track of clients and their handles...
#define SCARD_PRESENT
Card is present.
int SYS_USleep(int)
Makes the current process sleep for some microseconds.
#define SCARD_NEGOTIABLE
Ready for PTS.
#define SCARD_F_UNKNOWN_ERROR
An internal error has been detected, but the source is unknown.
#define SCARD_E_NO_MEMORY
Not enough memory available to complete this command.
#define IFD_POWER_DOWN
power down the card
static list_t ClientsWaitingForEvent
list of client file descriptors
#define PCSCLITE_STATUS_POLL_RATE
Status polling rate.
LONG EHTryToUnregisterClientForEvent(int32_t filedes)
Try to unregisted a client If no client is found then do not log an error.
This handles card insertion/removal events, updates ATR, protocol, and status information.
pthread_mutex_t ClientsWaitingForEvent_lock
lock for the above list
#define SCARD_SWALLOWED
Card not powered.
int powerState
auto power off state
#define SCARD_PROTOCOL_UNDEFINED
protocol not set
UCHAR cardAtr[MAX_ATR_SIZE]
ATR.
LONG IFDPowerICC(READER_CONTEXT *rContext, DWORD dwAction, PUCHAR pucAtr, PDWORD pdwAtrLen)
Power up/down or reset's an ICC located in the IFD.
#define PCSCLITE_STATUS_EVENT_TIMEOUT
normal timeout for pthCardEvent driver function when no card or card in use
#define SCARD_POWERED
Card is powered.
#define PCSCLITE_POWER_OFF_GRACE_PERIOD
time to wait before powering down an unused card
This keeps a list of defines for pcsc-lite.
#define SCARD_ABSENT
Card is absent.
uint32_t cardProtocol
SCARD_PROTOCOL_* value.
This keeps track of a list of currently available reader structures.
uint32_t readerState
SCARD_* bit field.
#define SCARD_F_INTERNAL_ERROR
An internal consistency check failed.
pthread_mutex_t powerState_lock
powerState mutex
#define IFD_POWER_UP
power up the card
#define TAG_IFD_POLLING_THREAD_KILLABLE
the polling thread can be killed
#define IFD_SUCCESS
no error
#define SCARD_REMOVED
Card was removed.