FreeRDP
smartcard_main.h File Reference
#include <freerdp/channels/log.h>
#include <freerdp/channels/rdpdr.h>
#include <winpr/crt.h>
#include <winpr/wlog.h>
#include <winpr/synch.h>
#include <winpr/smartcard.h>
#include <winpr/collections.h>
#include "smartcard_operations.h"
#include "smartcard_pack.h"
This graph shows which files directly or indirectly include this file:

Data Structures

struct  SMARTCARD_CONTEXT
 
struct  SMARTCARD_DEVICE
 

Macros

#define TAG   CHANNELS_TAG("smartcard.client")
 

Functions

SMARTCARD_CONTEXT * smartcard_context_new (SMARTCARD_DEVICE *smartcard, SCARDCONTEXT hContext)
 
void smartcard_context_free (void *pContext)
 
LONG smartcard_irp_device_control_decode (SMARTCARD_DEVICE *smartcard, SMARTCARD_OPERATION *operation)
 
LONG smartcard_irp_device_control_call (SMARTCARD_DEVICE *smartcard, SMARTCARD_OPERATION *operation)
 

Macro Definition Documentation

◆ TAG

#define TAG   CHANNELS_TAG("smartcard.client")

FreeRDP: A Remote Desktop Protocol Implementation Smartcard Device Service Virtual Channel

Copyright 2011 O.S. Systems Software Ltda. Copyright 2011 Eduardo Fiss Beloni belon.nosp@m.i@os.nosp@m.syste.nosp@m.ms.c.nosp@m.om.br Copyright 2015 Thincast Technologies GmbH Copyright 2015 DI (FH) Martin Haimberger marti.nosp@m.n.ha.nosp@m.imber.nosp@m.ger@.nosp@m.thinc.nosp@m.ast..nosp@m.com

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

Function Documentation

◆ smartcard_context_free()

void smartcard_context_free ( void *  pContext)
Here is the call graph for this function:
Here is the caller graph for this function:

◆ smartcard_context_new()

SMARTCARD_CONTEXT* smartcard_context_new ( SMARTCARD_DEVICE *  smartcard,
SCARDCONTEXT  hContext 
)
Here is the call graph for this function:
Here is the caller graph for this function:

◆ smartcard_irp_device_control_call()

LONG smartcard_irp_device_control_call ( SMARTCARD_DEVICE *  smartcard,
SMARTCARD_OPERATION *  operation 
)

[MS-RDPESC] 3.2.5.1: Sending Outgoing Messages: the output buffer length SHOULD be set to 2048

Since it's a SHOULD and not a MUST, we don't care about it, but we still reserve at least 2048 bytes.

[MS-RPCE] 2.2.6.3 Primitive Type Serialization The type MUST be aligned on an 8-byte boundary. If the size of the primitive type is not a multiple of 8 bytes, the data MUST be padded.

Here is the caller graph for this function:

◆ smartcard_irp_device_control_decode()

LONG smartcard_irp_device_control_decode ( SMARTCARD_DEVICE *  smartcard,
SMARTCARD_OPERATION *  operation 
)
Here is the caller graph for this function: