Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
8490c43f
Commit
8490c43f
authored
Feb 16, 2023
by
Hans Leidekker
Committed by
Alexandre Julliard
Feb 22, 2023
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
winscard: Implement SCardEstablish/ReleaseContext() on top of libpcsclite.
parent
21059660
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
244 additions
and
36 deletions
+244
-36
configure
configure
+70
-4
configure.ac
configure.ac
+10
-0
Makefile.in
dlls/winscard/Makefile.in
+3
-0
unixlib.c
dlls/winscard/unixlib.c
+53
-0
unixlib.h
dlls/winscard/unixlib.h
+37
-0
winscard.c
dlls/winscard/winscard.c
+71
-32
No files found.
configure
View file @
8490c43f
...
...
@@ -700,6 +700,7 @@ DBUS_LIBS
DBUS_CFLAGS
INOTIFY_LIBS
INOTIFY_CFLAGS
PCSCLITE_LIBS
PCAP_LIBS
X_EXTRA_LIBS
X_LIBS
...
...
@@ -928,6 +929,7 @@ with_opengl
with_osmesa
with_oss
with_pcap
with_pcsclite
with_pthread
with_pulse
with_sane
...
...
@@ -2445,6 +2447,7 @@ Optional Packages:
--without-osmesa do not use the OSMesa library
--without-oss do not use the OSS sound support
--without-pcap do not use the Packet Capture library
--without-pcsclite do not use PCSC lite
--without-pthread do not use the pthread library
--without-pulse do not use PulseAudio sound support
--without-sane do not use SANE (scanner support)
...
...
@@ -4308,6 +4311,13 @@ then :
fi
# Check whether --with-pcsclite was given.
if
test
${
with_pcsclite
+y
}
then
:
withval
=
$with_pcsclite
;
fi
# Check whether --with-pthread was given.
if
test
${
with_pthread
+y
}
then
:
...
...
@@ -5864,11 +5874,11 @@ if test x$ac_prog_cxx_stdcxx = xno
then
:
{
printf
"%s
\n
"
"
$as_me
:
${
as_lineno
-
$LINENO
}
: checking for
$CXX
option to enable C++11 features"
>
&5
printf
%s
"checking for
$CXX
option to enable C++11 features... "
>
&6
;
}
if
test
${
ac_cv_prog_cxx_11
+y
}
if
test
${
ac_cv_prog_cxx_
cxx
11
+y
}
then
:
printf
%s
"(cached) "
>
&6
else
$as_nop
ac_cv_prog_cxx_11
=
no
ac_cv_prog_cxx_
cxx
11
=
no
ac_save_CXX
=
$CXX
cat
confdefs.h -
<<
_ACEOF
>conftest.
$ac_ext
/* end confdefs.h. */
...
...
@@ -5910,11 +5920,11 @@ if test x$ac_prog_cxx_stdcxx = xno
then
:
{
printf
"%s
\n
"
"
$as_me
:
${
as_lineno
-
$LINENO
}
: checking for
$CXX
option to enable C++98 features"
>
&5
printf
%s
"checking for
$CXX
option to enable C++98 features... "
>
&6
;
}
if
test
${
ac_cv_prog_cxx_98
+y
}
if
test
${
ac_cv_prog_cxx_
cxx
98
+y
}
then
:
printf
%s
"(cached) "
>
&6
else
$as_nop
ac_cv_prog_cxx_98
=
no
ac_cv_prog_cxx_
cxx
98
=
no
ac_save_CXX
=
$CXX
cat
confdefs.h -
<<
_ACEOF
>conftest.
$ac_ext
/* end confdefs.h. */
...
...
@@ -15761,6 +15771,61 @@ esac
enable_wpcap
=
${
enable_wpcap
:-
no
}
fi
if
test
"x
$with_pcsclite
"
!=
"xno"
then
{
printf
"%s
\n
"
"
$as_me
:
${
as_lineno
-
$LINENO
}
: checking for SCardEstablishContext in -lpcsclite"
>
&5
printf
%s
"checking for SCardEstablishContext in -lpcsclite... "
>
&6
;
}
if
test
${
ac_cv_lib_pcsclite_SCardEstablishContext
+y
}
then
:
printf
%s
"(cached) "
>
&6
else
$as_nop
ac_check_lib_save_LIBS
=
$LIBS
LIBS
=
"-lpcsclite
$LIBS
"
cat
confdefs.h -
<<
_ACEOF
>conftest.
$ac_ext
/* end confdefs.h. */
/* Override any GCC internal prototype to avoid an error.
Use char because int might match the return type of a GCC
builtin and then its argument prototype would still apply. */
char SCardEstablishContext ();
int
main (void)
{
return SCardEstablishContext ();
;
return 0;
}
_ACEOF
if
ac_fn_c_try_link
"
$LINENO
"
then
:
ac_cv_lib_pcsclite_SCardEstablishContext
=
yes
else
$as_nop
ac_cv_lib_pcsclite_SCardEstablishContext
=
no
fi
rm
-f
core conftest.err conftest.
$ac_objext
conftest.beam
\
conftest
$ac_exeext
conftest.
$ac_ext
LIBS
=
$ac_check_lib_save_LIBS
fi
{
printf
"%s
\n
"
"
$as_me
:
${
as_lineno
-
$LINENO
}
: result:
$ac_cv_lib_pcsclite_SCardEstablishContext
"
>
&5
printf
"%s
\n
"
"
$ac_cv_lib_pcsclite_SCardEstablishContext
"
>
&6
;
}
if
test
"x
$ac_cv_lib_pcsclite_SCardEstablishContext
"
=
xyes
then
:
PCSCLITE_LIBS
=
"-lpcsclite"
fi
fi
if
test
"x
$ac_cv_lib_pcsclite_SCardEstablishContext
"
!=
xyes
then
:
case
"x
$with_pcsclite
"
in
x
)
as_fn_append wine_notices
"|libpcsclite not found, smart cards won't be supported."
;;
xno
)
;;
*
)
as_fn_error
$?
"libpcsclite not found, smart cards won't be supported.
This is an error since --with-pcsclite was requested."
"
$LINENO
"
5
;;
esac
enable_winscard
=
${
enable_winscard
:-
no
}
fi
if
test
"x
$with_inotify
"
!=
"xno"
then
rm
-f
conftest.err
...
...
@@ -23087,6 +23152,7 @@ X_PRE_LIBS = $X_PRE_LIBS
X_LIBS =
$X_LIBS
X_EXTRA_LIBS =
$X_EXTRA_LIBS
PCAP_LIBS =
$PCAP_LIBS
PCSCLITE_LIBS =
$PCSCLITE_LIBS
INOTIFY_CFLAGS =
$INOTIFY_CFLAGS
INOTIFY_LIBS =
$INOTIFY_LIBS
DBUS_CFLAGS =
$DBUS_CFLAGS
...
...
configure.ac
View file @
8490c43f
...
...
@@ -50,6 +50,7 @@ AC_ARG_WITH(osmesa, AS_HELP_STRING([--without-osmesa],[do not use the OSMesa
AC_ARG_WITH(oss, AS_HELP_STRING([--without-oss],[do not use the OSS sound support]))
AC_ARG_WITH(pcap, AS_HELP_STRING([--without-pcap],[do not use the Packet Capture library]),
[if test "x$withval" = "xno"; then ac_cv_header_pcap_pcap_h=no; fi])
AC_ARG_WITH(pcsclite, AS_HELP_STRING([--without-pcsclite],[do not use PCSC lite]))
AC_ARG_WITH(pthread, AS_HELP_STRING([--without-pthread],[do not use the pthread library]),
[if test "x$withval" = "xno"; then ac_cv_header_pthread_h=no; fi])
AC_ARG_WITH(pulse, AS_HELP_STRING([--without-pulse],[do not use PulseAudio sound support]))
...
...
@@ -1377,6 +1378,15 @@ WINE_NOTICE_WITH(pcap,[test "x$ac_cv_lib_pcap_pcap_init" != xyes],
[pcap ${notice_platform}development files not found, wpcap won't be supported.],
[enable_wpcap])
dnl **** Check for libpcsclite ****
if test "x$with_pcsclite" != "xno"
then
AC_CHECK_LIB(pcsclite,SCardEstablishContext,[AC_SUBST(PCSCLITE_LIBS,["-lpcsclite"])])
fi
WINE_NOTICE_WITH(pcsclite,[test "x$ac_cv_lib_pcsclite_SCardEstablishContext" != xyes],
[libpcsclite not found, smart cards won't be supported.],
[enable_winscard])
dnl **** Check for inotify ****
if test "x$with_inotify" != "xno"
then
...
...
dlls/winscard/Makefile.in
View file @
8490c43f
MODULE
=
winscard.dll
IMPORTLIB
=
winscard
UNIXLIB
=
winscard.so
UNIX_LIBS
=
$(PCSCLITE_LIBS)
C_SRCS
=
\
unixlib.c
\
winscard.c
RC_SRCS
=
\
...
...
dlls/winscard/unixlib.c
0 → 100644
View file @
8490c43f
/*
* Copyright 2022 Hans Leidekker for CodeWeavers
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
*/
#if 0
#pragma makedep unix
#endif
#include <stdarg.h>
#include "ntstatus.h"
#define WIN32_NO_STATUS
#include "windef.h"
#include "winternl.h"
#include "winbase.h"
#include "wine/debug.h"
#include "wine/unixlib.h"
#include "unixlib.h"
LONG
SCardEstablishContext
(
UINT64
,
const
void
*
,
const
void
*
,
UINT64
*
);
LONG
SCardReleaseContext
(
UINT64
);
static
NTSTATUS
scard_establish_context
(
void
*
args
)
{
struct
scard_establish_context_params
*
params
=
args
;
return
SCardEstablishContext
(
params
->
scope
,
NULL
,
NULL
,
params
->
handle
);
}
static
NTSTATUS
scard_release_context
(
void
*
args
)
{
struct
scard_release_context_params
*
params
=
args
;
return
SCardReleaseContext
(
params
->
handle
);
}
const
unixlib_entry_t
__wine_unix_call_funcs
[]
=
{
scard_establish_context
,
scard_release_context
,
};
dlls/winscard/unixlib.h
0 → 100644
View file @
8490c43f
/*
* Copyright 2022 Hans Leidekker for CodeWeavers
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
*/
/* pcsclite defines DWORD as unsigned long on 64-bit (except on macOS),
* so use UINT64 instead. */
struct
scard_establish_context_params
{
UINT64
scope
;
UINT64
*
handle
;
};
struct
scard_release_context_params
{
UINT64
handle
;
};
enum
winscard_funcs
{
unix_scard_establish_context
,
unix_scard_release_context
,
};
dlls/winscard/winscard.c
View file @
8490c43f
/*
* Copyright 2007 Mounir IDRASSI (mounir.idrassi@idrix.fr, for IDRIX)
* Copyright 2022 Hans Leidekker for CodeWeavers
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
...
...
@@ -19,39 +20,23 @@
#include <stdarg.h>
#include "windef.h"
#include "winbase.h"
#include "wine/debug.h"
#include "winscard.h"
#include "winternl.h"
#include "wine/debug.h"
#include "wine/unixlib.h"
#include "unixlib.h"
WINE_DEFAULT_DEBUG_CHANNEL
(
winscard
);
static
HANDLE
g_startedEvent
=
NULL
;
#define UNIX_CALL( func, params ) WINE_UNIX_CALL( unix_ ## func, params )
static
HANDLE
g_startedEvent
;
const
SCARD_IO_REQUEST
g_rgSCardT0Pci
=
{
SCARD_PROTOCOL_T0
,
8
};
const
SCARD_IO_REQUEST
g_rgSCardT1Pci
=
{
SCARD_PROTOCOL_T1
,
8
};
const
SCARD_IO_REQUEST
g_rgSCardRawPci
=
{
SCARD_PROTOCOL_RAW
,
8
};
BOOL
WINAPI
DllMain
(
HINSTANCE
hinstDLL
,
DWORD
fdwReason
,
LPVOID
lpvReserved
)
{
TRACE
(
"%p,%lx,%p
\n
"
,
hinstDLL
,
fdwReason
,
lpvReserved
);
switch
(
fdwReason
)
{
case
DLL_PROCESS_ATTACH
:
DisableThreadLibraryCalls
(
hinstDLL
);
/* FIXME: for now, we act as if the pcsc daemon is always started */
g_startedEvent
=
CreateEventA
(
NULL
,
TRUE
,
TRUE
,
NULL
);
break
;
case
DLL_PROCESS_DETACH
:
if
(
lpvReserved
)
break
;
CloseHandle
(
g_startedEvent
);
break
;
}
return
TRUE
;
}
HANDLE
WINAPI
SCardAccessStartedEvent
(
void
)
{
return
g_startedEvent
;
...
...
@@ -81,12 +66,32 @@ LONG WINAPI SCardAddReaderToGroupW(SCARDCONTEXT context, LPCWSTR reader, LPCWSTR
return
SCARD_S_SUCCESS
;
}
LONG
WINAPI
SCardEstablishContext
(
DWORD
dwScope
,
LPCVOID
pvReserved1
,
LPCVOID
pvReserved2
,
LPSCARDCONTEXT
phContext
)
#define CONTEXT_MAGIC (('C' << 24) | ('T' << 16) | ('X' << 8) | '0')
struct
handle
{
FIXME
(
"(%lx,%p,%p,%p) stub
\n
"
,
dwScope
,
pvReserved1
,
pvReserved2
,
phContext
);
SetLastError
(
ERROR_CALL_NOT_IMPLEMENTED
);
return
SCARD_F_INTERNAL_ERROR
;
DWORD
magic
;
UINT64
unix_handle
;
};
LONG
WINAPI
SCardEstablishContext
(
DWORD
scope
,
const
void
*
reserved1
,
const
void
*
reserved2
,
SCARDCONTEXT
*
context
)
{
struct
scard_establish_context_params
params
;
struct
handle
*
handle
;
LONG
ret
;
TRACE
(
"%#lx, %p, %p, %p
\n
"
,
scope
,
reserved1
,
reserved2
,
context
);
if
(
!
context
)
return
SCARD_E_INVALID_PARAMETER
;
if
(
!
(
handle
=
malloc
(
sizeof
(
*
handle
)
)))
return
SCARD_E_NO_MEMORY
;
handle
->
magic
=
CONTEXT_MAGIC
;
params
.
scope
=
scope
;
params
.
handle
=
&
handle
->
unix_handle
;
if
(
!
(
ret
=
UNIX_CALL
(
scard_establish_context
,
&
params
)))
*
context
=
(
SCARDCONTEXT
)
handle
;
else
free
(
handle
);
TRACE
(
"returning %#lx
\n
"
,
ret
);
return
ret
;
}
LONG
WINAPI
SCardIsValidContext
(
SCARDCONTEXT
context
)
...
...
@@ -103,11 +108,23 @@ LONG WINAPI SCardListCardsA(SCARDCONTEXT hContext, LPCBYTE pbAtr, LPCGUID rgguid
return
SCARD_F_INTERNAL_ERROR
;
}
LONG
WINAPI
SCardReleaseContext
(
SCARDCONTEXT
context
)
LONG
WINAPI
SCardReleaseContext
(
SCARDCONTEXT
context
)
{
FIXME
(
"(%Ix) stub
\n
"
,
context
);
SetLastError
(
ERROR_CALL_NOT_IMPLEMENTED
);
return
SCARD_F_INTERNAL_ERROR
;
struct
handle
*
handle
=
(
struct
handle
*
)
context
;
struct
scard_release_context_params
params
;
LONG
ret
;
TRACE
(
"%Ix
\n
"
,
context
);
if
(
!
handle
||
handle
->
magic
!=
CONTEXT_MAGIC
)
return
ERROR_INVALID_HANDLE
;
params
.
handle
=
handle
->
unix_handle
;
ret
=
UNIX_CALL
(
scard_release_context
,
&
params
);
handle
->
magic
=
0
;
free
(
handle
);
TRACE
(
"returning %#lx
\n
"
,
ret
);
return
ret
;
}
LONG
WINAPI
SCardStatusA
(
SCARDHANDLE
context
,
LPSTR
szReaderName
,
LPDWORD
pcchReaderLen
,
LPDWORD
pdwState
,
LPDWORD
pdwProtocol
,
LPBYTE
pbAtr
,
LPDWORD
pcbAtrLen
)
...
...
@@ -147,3 +164,25 @@ LONG WINAPI SCardCancel(SCARDCONTEXT context)
SetLastError
(
ERROR_CALL_NOT_IMPLEMENTED
);
return
SCARD_F_INTERNAL_ERROR
;
}
BOOL
WINAPI
DllMain
(
HINSTANCE
hinst
,
DWORD
reason
,
void
*
reserved
)
{
switch
(
reason
)
{
case
DLL_PROCESS_ATTACH
:
DisableThreadLibraryCalls
(
hinst
);
if
(
__wine_init_unix_call
())
ERR
(
"no pcsclite support, expect problems
\n
"
);
/* FIXME: for now, we act as if the pcsc daemon is always started */
g_startedEvent
=
CreateEventW
(
NULL
,
TRUE
,
TRUE
,
NULL
);
break
;
case
DLL_PROCESS_DETACH
:
if
(
reserved
)
break
;
CloseHandle
(
g_startedEvent
);
g_startedEvent
=
NULL
;
break
;
}
return
TRUE
;
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment