qemu-devel
[Top][All Lists]
Advanced

[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



reply via email to

[Prev in Thread] Current Thread [Next in Thread]