[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [PATCH v23 08/11] libcacard: add passthru
From: |
Alon Levy |
Subject: |
Re: [Qemu-devel] [PATCH v23 08/11] libcacard: add passthru |
Date: |
Mon, 28 Mar 2011 17:21:47 +0200 |
User-agent: |
Mutt/1.5.21 (2010-09-15) |
On Mon, Mar 28, 2011 at 03:27:49PM +0200, Jes Sorensen wrote:
> On 03/23/11 14:19, Alon Levy wrote:
> > diff --git a/libcacard/passthru.c b/libcacard/passthru.c
> > new file mode 100644
> > index 0000000..d78e2db
> > --- /dev/null
> > +++ b/libcacard/passthru.c
> > @@ -0,0 +1,609 @@
> > +/*
> > + * implement the applets for the CAC card.
> > + *
> > + * This work is licensed under the terms of the GNU LGPL, version 2.1 or
> > later.
> > + * See the COPYING.LIB file in the top-level directory.
> > + */
> > +#ifdef USE_PASSTHRU
> > +#include <stdlib.h>
> > +#include <string.h>
> > +
> > +#include <pcsclite.h>
> > +
> > +#include "qemu-thread.h"
> > +
> > +#include "vcard.h"
> > +#include "vcard_emul.h"
> > +#include "card_7816.h"
> > +#include "vreader.h"
> > +#include "vcard_emul.h"
> > +#include "passthru.h"
> > +
> > +/*
> > + * Passthru applet private data
> > + */
> > +struct VCardAppletPrivateStruct {
> > + char *reader_name;
> > + /* pcsc-lite parameters */
> > + SCARDHANDLE hCard;
> > + uint32_t hProtocol;
> > + SCARD_IO_REQUEST *send_io;
> > + unsigned char atr[MAX_ATR_SIZE];
> > + int atr_len;
> > +};
> > +
> > +static SCARDCONTEXT global_context;
> > +
> > +#define MAX_RESPONSE_LENGTH 261 /*65537 */
> > +/*
> > + * handle all the APDU's that are common to all CAC applets
> > + */
> > +static VCardStatus
> > +passthru_process_apdu(VCard *card, VCardAPDU *apdu, VCardResponse
> > **response)
> > +{
> > + LONG rv;
>
> Where does this odd LONG type come from? I think Windows uses LONG so
> having your own type would conflict with that, and of course we don't
> really want Windows types directly in QEMU either, so I am curious?
>
This comes from pcsclite (which means I need to add the dependency to configure,
I'll fix this). From there it comes via an include called wintypes.h. the PCSC
API
is actually a copy of a microsoft API, so it makes sense that it uses those
types.
On windows pcsclite won't be needed, since it has a native equivalent API, so
there
won't be a redefinition of LONG.
So the real fix is that I need to add yet another dependency for qemu's
configure,
for pcsc-lite - but right now the whole libcacard/passthru.c is protected by an
"#ifdef USE_PASSTHRU", which we don't define - so in effect this is currently
dead
code. I could even just remove this commit in its entirety atm, maybe best?
Notice
that has nothing to do with ccid-card-emulated or with ccid-card-passthru. I
will
need it later, but I need to add the pcsclite configure check anyway. So is
this ok,
I'll drop this patch?
> Otherwise the code looks fine.
>
> Cheers,
> Jes
- Re: [Qemu-devel] [PATCH v23 03/11] usb-ccid: add CCID bus, (continued)
- Re: [Qemu-devel] [PATCH v23 03/11] usb-ccid: add CCID bus, Jes Sorensen, 2011/03/28
- Re: [Qemu-devel] [PATCH v23 03/11] usb-ccid: add CCID bus, Alon Levy, 2011/03/28
- Re: [Qemu-devel] [PATCH v23 03/11] usb-ccid: add CCID bus, Alon Levy, 2011/03/28
- Re: [Qemu-devel] [PATCH v23 03/11] usb-ccid: add CCID bus, Jes Sorensen, 2011/03/28
- Re: [Qemu-devel] [PATCH v23 03/11] usb-ccid: add CCID bus, Blue Swirl, 2011/03/28
- Re: [Qemu-devel] [PATCH v23 03/11] usb-ccid: add CCID bus, Alon Levy, 2011/03/28
- Re: [Qemu-devel] [PATCH v23 03/11] usb-ccid: add CCID bus, Blue Swirl, 2011/03/28
[Qemu-devel] [PATCH v23 08/11] libcacard: add passthru, Alon Levy, 2011/03/23
[Qemu-devel] [PATCH v23 09/11] libcacard: add docs, Alon Levy, 2011/03/23
[Qemu-devel] [PATCH v23 07/11] libcacard: add vscclient, Alon Levy, 2011/03/23
[Qemu-devel] [PATCH v23 11/11] ccid: add docs, Alon Levy, 2011/03/23
[Qemu-devel] [PATCH v23 10/11] ccid: add ccid-card-emulated device, Alon Levy, 2011/03/23