blob: 75cc2716f18f0be26bcf0cdb4e162d5aa2021922 [file] [log] [blame]
/** MobiCore driver module.(interface to the secure world SWD)
* @addtogroup MCD_MCDIMPL_KMOD_IMPL
* @{
* @file
* MobiCore Driver Kernel Module.
*
* <!-- Copyright Giesecke & Devrient GmbH 2009-2012 -->
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*/
#include <linux/module.h>
#include "main.h"
#include "mem.h"
#include "debug.h"
/**
* Map a virtual memory buffer structure to Mobicore
* @param instance
* @param addr address of the buffer(NB it must be kernel virtual!)
* @param len buffer length
* @param handle pointer to handle
* @param phys_wsm_l2_table pointer to physical L2 table(?)
*
* @return 0 if no error
*
*/
int mobicore_map_vmem(struct mc_instance *instance, void *addr,
uint32_t len, uint32_t *handle, uint32_t *phys)
{
return mc_register_wsm_l2(instance, (uint32_t)addr, len,
handle, phys);
}
EXPORT_SYMBOL(mobicore_map_vmem);
/**
* Unmap a virtual memory buffer from mobicore
* @param instance
* @param handle
*
* @return 0 if no error
*
*/
int mobicore_unmap_vmem(struct mc_instance *instance, uint32_t handle)
{
return mc_unregister_wsm_l2(instance, handle);
}
EXPORT_SYMBOL(mobicore_unmap_vmem);
/**
* Free a WSM buffer allocated with mobicore_allocate_wsm
* @param instance
* @param handle handle of the buffer
*
* @return 0 if no error
*
*/
int mobicore_free_wsm(struct mc_instance *instance, uint32_t handle)
{
return mc_free_buffer(instance, handle);
}
EXPORT_SYMBOL(mobicore_free_wsm);
/**
* Allocate WSM for given instance
*
* @param instance instance
* @param requested_size size of the WSM
* @param handle pointer where the handle will be saved
* @param virt_kernel_addr pointer for the kernel virtual address
* @param phys_addr pointer for the physical address
*
* @return error code or 0 for success
*/
int mobicore_allocate_wsm(struct mc_instance *instance,
unsigned long requested_size, uint32_t *handle, void **virt_kernel_addr,
void **phys_addr)
{
struct mc_buffer *buffer = NULL;
/* Setup the WSM buffer structure! */
if (mc_get_buffer(instance, &buffer, requested_size))
return -EFAULT;
*handle = buffer->handle;
*phys_addr = buffer->phys;
*virt_kernel_addr = buffer->addr;
return 0;
}
EXPORT_SYMBOL(mobicore_allocate_wsm);
/**
* Initialize a new mobicore API instance object
*
* @return Instance or NULL if no allocation was possible.
*/
struct mc_instance *mobicore_open(void)
{
return mc_alloc_instance();
}
EXPORT_SYMBOL(mobicore_open);
/**
* Release a mobicore instance object and all objects related to it
* @param instance instance
* @return 0 if Ok or -E ERROR
*/
int mobicore_release(struct mc_instance *instance)
{
return mc_release_instance(instance);
}
EXPORT_SYMBOL(mobicore_release);
/** @} */