pcsc-lite 2.5.0
readerfactory.h
Go to the documentation of this file.
1/*
2 * MUSCLE SmartCard Development ( https://pcsclite.apdu.fr/ )
3 *
4 * Copyright (C) 1999
5 * David Corcoran <corcoran@musclecard.com>
6 * Copyright (C) 2002-2023
7 * Ludovic Rousseau <ludovic.rousseau@free.fr>
8 *
9Redistribution and use in source and binary forms, with or without
10modification, are permitted provided that the following conditions
11are met:
12
131. Redistributions of source code must retain the above copyright
14 notice, this list of conditions and the following disclaimer.
152. Redistributions in binary form must reproduce the above copyright
16 notice, this list of conditions and the following disclaimer in the
17 documentation and/or other materials provided with the distribution.
183. The name of the author may not be used to endorse or promote products
19 derived from this software without specific prior written permission.
20
21THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
22IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
23OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
24IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
25INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
26NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
30THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31 */
32
37
38#ifndef __readerfactory_h__
39#define __readerfactory_h__
40
41
42#include "ifdhandler.h"
43#include "pcscd.h"
44#include "readers.h"
45
46 typedef struct
47 {
50 char *pcLibpath;
53
55 {
57 _Atomic DWORD dwEventStatus;
58 };
59
60 typedef struct RdrCliHandles RDR_CLIHANDLES;
61
62 LONG _RefReader(READER_CONTEXT * sReader);
63 LONG _UnrefReader(READER_CONTEXT * sReader);
64
65#define REF_READER(reader) { LONG rv; Log2(PCSC_LOG_DEBUG, "RefReader() count was: %d", reader->reference); rv = _RefReader(reader); if (rv != SCARD_S_SUCCESS) return rv; }
66#define UNREF_READER(reader) {Log2(PCSC_LOG_DEBUG, "UnrefReader() count was: %d", reader->reference); _UnrefReader(reader);}
67
68 LONG RFAllocateReaderSpace(unsigned int);
69 LONG RFAddReader(const char *, int, const char *, const char *);
70 LONG RFRemoveReader(const char *, int, int);
71 LONG RFSetReaderName(READER_CONTEXT *, const char *, const char *, int);
72 LONG RFReaderInfo(const char *, /*@out@*/ struct ReaderContext **);
73 LONG RFReaderInfoById(SCARDHANDLE, /*@out@*/ struct ReaderContext **);
74 LONG RFCheckSharing(SCARDHANDLE, READER_CONTEXT *);
75 LONG RFLockSharing(SCARDHANDLE, READER_CONTEXT *);
76 LONG RFUnlockSharing(SCARDHANDLE, READER_CONTEXT *);
77 LONG RFUnlockAllSharing(SCARDHANDLE, READER_CONTEXT *);
78 LONG RFLoadReader(READER_CONTEXT *);
79 LONG RFBindFunctions(READER_CONTEXT *);
80 LONG RFUnBindFunctions(READER_CONTEXT *);
81 LONG RFUnloadReader(READER_CONTEXT *);
82 LONG RFInitializeReader(READER_CONTEXT *);
83 void RFUnInitializeReader(READER_CONTEXT *);
84 SCARDHANDLE RFCreateReaderHandle(READER_CONTEXT *);
85 LONG RFAddReaderHandle(READER_CONTEXT *, SCARDHANDLE);
86 LONG RFRemoveReaderHandle(READER_CONTEXT *, SCARDHANDLE);
87 void RFSetReaderEventState(READER_CONTEXT *, DWORD);
88 LONG RFCheckReaderEventState(READER_CONTEXT *, SCARDHANDLE);
89 LONG RFClearReaderEventState(READER_CONTEXT *, SCARDHANDLE);
90 LONG RFCheckReaderStatus(READER_CONTEXT *);
91 void RFCleanupReaders(void);
92 void RFWaitForReaderInit(void);
93 int RFStartSerialReaders(const char *readerconf);
94 void RFReCheckReaderConf(void);
95 int RFGetPowerState(READER_CONTEXT *);
96 void RFSetPowerState(READER_CONTEXT *, int value);
97
98#define REMOVE_READER_NO_FLAG 0
99#define REMOVE_READER_FLAG_REMOVED 1
100
101#endif
LONG SCARDHANDLE
hCard returned by SCardConnect()
Definition pcsclite.h:55
int RFGetPowerState(READER_CONTEXT *)
Wait until all connected readers have a chance to power up a possibly inserted card.
define structures to represent a reader
SCARDHANDLE hCard
hCard for this connection
_Atomic DWORD dwEventStatus
Recent event that must be sent.
int channelId
CHANNELID.
char * pcFriendlyname
FRIENDLYNAME.
char * pcLibpath
LIBPATH.
char * pcDevicename
DEVICENAME.