blob: 20204d82f7bbd8cecb4c4837848f130be9390c0a [file] [log] [blame]
/** @addtogroup MCD_MCDIMPL_DAEMON_KERNEL
* @{
* @file
*
* MobiCore Driver Kernel Module Interface.
*
* <!-- Copyright Giesecke & Devrient GmbH 2009 - 2012 -->
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. The name of the author may not be used to endorse or promote
* products derived from this software without specific prior
* written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS
* OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
* GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef CMCKMOD_H_
#define CMCKMOD_H_
#include <stdint.h>
#include "McTypes.h"
#include "CKMod.h"
#define ERROR_MAPPING_FAILED ((int)(-2))
/**
* As this is also used by the ClientLib, we do not use exceptions.
*/
class CMcKMod : public CKMod {
public:
/**
* Map data.
*
* @param len
* @param pHandle
* @param pVirtAddr
* @param pPhysAddr
* @param pMciReuse [in|out] set to true [in] for reusing MCI buffer
* is set to true [out] if MCI buffer has been reused
* @return 0 if all went fine
* @return ERROR_KMOD_NOT_OPEN
* @return ERROR_MAPPING_FAILED
*/
int mmap(
uint32_t len,
uint32_t *pHandle,
addr_t *pVirtAddr,
addr_t *pPhysAddr,
bool *pMciReuse
);
/**
* Map persistent WSM which will not be freed up once the calling process dies.
*/
int mapPersistent(
uint32_t len,
uint32_t *pHandle,
addr_t *pVirtAddr,
addr_t *pPhysAddr
);
int read(
addr_t buffer,
uint32_t len
);
bool waitSSIQ(
uint32_t *pCnt
);
int fcInit(
addr_t mciBuffer,
uint32_t nqOffset,
uint32_t nqLength,
uint32_t mcpOffset,
uint32_t mcpLength
);
int fcInfo(
uint32_t extInfoId,
uint32_t *pState,
uint32_t *pExtInfo
);
int fcYield(
void
);
int fcNSIQ(
void
);
int free(
uint32_t handle
);
int registerWsmL2(
addr_t buffer,
uint32_t len,
uint32_t pid,
uint32_t *pHandle,
addr_t *pPhysWsmL2
);
int unregisterWsmL2(
uint32_t handle
);
/**
* Tell stub to start MobiCore from given physical address
*/
int fcExecute(
addr_t startAddr,
uint32_t areaLength
);
bool checkKmodVersionOk(
void
);
};
typedef CMcKMod *CMcKMod_ptr;
#endif // CMCKMOD_H_