Commit 45741120 authored by C A Subramaniam's avatar C A Subramaniam Committed by Hari Kanigeri

SYSLINK: PROCMGR - Patch to move to syslink version 2.0.0.12

Thi patch has changes to migrate to syslink version 2.0.0.12
Also added some additional checks. Added -EINVAL return code
for invalid arguments.
Signed-off-by: default avatarC A Subramaniam <subramaniam.ca@gmail.com>
parent a169a5df
......@@ -34,6 +34,7 @@
#include <syslink/multiproc.h>
#include <syslink/ducatienabler.h>
#include <syslink/platform_mem.h>
#include <syslink/atomic_linux.h>
#define DUCATI_DMM_START_ADDR 0xa0000000
#define DUCATI_DMM_POOL_SIZE 0x6000000
......@@ -47,6 +48,10 @@
#define RM_MPU_M3_RST2 0x2
#define RM_MPU_M3_RST3 0x4
#define OMAP4430PROC_MODULEID (u16) 0xbbec
/* Macro to make a correct module magic number with refCount */
#define OMAP4430PROC_MAKE_MAGICSTAMP(x) ((OMAP4430PROC_MODULEID << 12u) | (x))
/*OMAP4430 Module state object */
struct proc4430_module_object {
......@@ -58,12 +63,11 @@ struct proc4430_module_object {
/* Default module configuration */
struct proc4430_params def_inst_params;
/* Default parameters for the OMAP4430 instances */
bool is_setup;
/* Indicates whether the OMAP4430 module is setup. */
void *proc_handles[MULTIPROC_MAXPROCESSORS];
/* Processor handle array. */
struct mutex *gate_handle;
/* void * of gate to be used for local thread safety */
atomic_t ref_count;
};
/*
......@@ -84,7 +88,6 @@ struct proc4430_object {
*/
static struct proc4430_module_object proc4430_state = {
.is_setup = false,
.config_size = sizeof(struct proc4430_config),
.gate_handle = NULL,
.def_inst_params.num_mem_entries = 0u,
......@@ -134,6 +137,14 @@ int proc4430_setup(struct proc4430_config *cfg)
{
int retval = 0;
struct proc4430_config tmp_cfg;
atomic_cmpmask_and_set(&proc4430_state.ref_count,
OMAP4430PROC_MAKE_MAGICSTAMP(0),
OMAP4430PROC_MAKE_MAGICSTAMP(0));
if (atomic_inc_return(&proc4430_state.ref_count) !=
OMAP4430PROC_MAKE_MAGICSTAMP(1)) {
return 1;
}
if (cfg == NULL) {
proc4430_get_config(&tmp_cfg);
......@@ -141,24 +152,35 @@ int proc4430_setup(struct proc4430_config *cfg)
}
/* Put SYS-M3 and APP M3 in reset */
__raw_writel(0x03, CORE_PRM_BASE + RM_MPU_M3_RSTCTRL_OFFSET);
if (proc4430_state.is_setup == false) {
dmm_create();
dmm_create_tables(DUCATI_DMM_START_ADDR, DUCATI_DMM_POOL_SIZE);
/* Create a default gate handle for local module protection. */
proc4430_state.gate_handle =
kmalloc(sizeof(struct mutex), GFP_KERNEL);
if (proc4430_state.gate_handle == NULL) {
retval = -ENOMEM;
goto error;
}
mutex_init(proc4430_state.gate_handle);
ducati_setup();
/* Initialize the name to handles mapping array. */
memset(&proc4430_state.proc_handles, 0,
(sizeof(void *) * MULTIPROC_MAXPROCESSORS));
proc4430_state.is_setup = true;
}
/* Copy the user provided values into the state object. */
memcpy(&proc4430_state.cfg, cfg,
sizeof(struct proc4430_config));
return 0;
error:
atomic_dec_return(&proc4430_state.ref_count);
dmm_delete_tables();
dmm_destroy();
return retval;
}
EXPORT_SYMBOL(proc4430_setup);
......@@ -175,9 +197,24 @@ int proc4430_destroy(void)
int retval = 0;
u16 i;
/* Check if any OMAP4430 instances have not been deleted so far. If not,
* delete them.
if (atomic_cmpmask_and_lt(&proc4430_state.ref_count,
OMAP4430PROC_MAKE_MAGICSTAMP(0),
OMAP4430PROC_MAKE_MAGICSTAMP(1))
== true) {
retval = -ENODEV;
goto exit;
}
if (!(atomic_dec_return(&proc4430_state.ref_count)
== OMAP4430PROC_MAKE_MAGICSTAMP(0))) {
retval = 1;
goto exit;
}
/* Check if any OMAP4430 instances have not been
* deleted so far. If not,delete them.
*/
for (i = 0; i < MULTIPROC_MAXPROCESSORS; i++) {
if (proc4430_state.proc_handles[i] == NULL)
continue;
......@@ -189,9 +226,9 @@ int proc4430_destroy(void)
mutex_destroy(proc4430_state.gate_handle);
kfree(proc4430_state.gate_handle);
}
ducati_destroy();
proc4430_state.is_setup = false;
exit:
return retval;
}
EXPORT_SYMBOL(proc4430_destroy);
......@@ -204,7 +241,22 @@ void proc4430_params_init(void *handle, struct proc4430_params *params)
{
struct proc4430_object *proc_object = (struct proc4430_object *)handle;
BUG_ON(params == NULL);
if (atomic_cmpmask_and_lt(&proc4430_state.ref_count,
OMAP4430PROC_MAKE_MAGICSTAMP(0),
OMAP4430PROC_MAKE_MAGICSTAMP(1))
== true) {
printk(KERN_ERR "proc4430_params_init failed "
"Module not initialized");
return;
}
if (WARN_ON(params == NULL)) {
printk(KERN_ERR "proc4430_params_init failed "
"Argument of type proc4430_params * "
"is NULL");
return;
}
if (handle == NULL)
memcpy(params, &(proc4430_state.def_inst_params),
sizeof(struct proc4430_params));
......@@ -226,6 +278,15 @@ void *proc4430_create(u16 proc_id, const struct proc4430_params *params)
BUG_ON(!IS_VALID_PROCID(proc_id));
BUG_ON(params == NULL);
if (atomic_cmpmask_and_lt(&proc4430_state.ref_count,
OMAP4430PROC_MAKE_MAGICSTAMP(0),
OMAP4430PROC_MAKE_MAGICSTAMP(1))
== true) {
printk(KERN_ERR "proc4430_create failed "
"Module not initialized");
goto error;
}
/* Enter critical section protection. */
WARN_ON(mutex_lock_interruptible(proc4430_state.gate_handle));
if (proc4430_state.proc_handles[proc_id] != NULL) {
......@@ -251,8 +312,7 @@ void *proc4430_create(u16 proc_id, const struct proc4430_params *params)
handle->proc_fxn_table.procinfo = &proc4430_proc_info;
handle->proc_fxn_table.virt_to_phys = &proc4430_virt_to_phys;
handle->state = PROC_MGR_STATE_UNKNOWN;
handle->object = vmalloc
(sizeof(struct proc4430_object));
handle->object = vmalloc(sizeof(struct proc4430_object));
handle->proc_id = proc_id;
object = (struct proc4430_object *)handle->object;
if (params != NULL) {
......@@ -278,6 +338,7 @@ void *proc4430_create(u16 proc_id, const struct proc4430_params *params)
func_end:
mutex_unlock(proc4430_state.gate_handle);
error:
return (void *)handle;
}
EXPORT_SYMBOL(proc4430_create);
......@@ -298,6 +359,15 @@ int proc4430_delete(void **handle_ptr)
BUG_ON(handle_ptr == NULL);
BUG_ON(*handle_ptr == NULL);
if (atomic_cmpmask_and_lt(&proc4430_state.ref_count,
OMAP4430PROC_MAKE_MAGICSTAMP(0),
OMAP4430PROC_MAKE_MAGICSTAMP(1))
== true) {
printk(KERN_ERR "proc4430_delete failed "
"Module not initialized");
return -ENODEV;
}
handle = (struct processor_object *)(*handle_ptr);
BUG_ON(!IS_VALID_PROCID(handle->proc_id));
/* Enter critical section protection. */
......@@ -335,6 +405,15 @@ int proc4430_open(void **handle_ptr, u16 proc_id)
BUG_ON(handle_ptr == NULL);
BUG_ON(!IS_VALID_PROCID(proc_id));
if (atomic_cmpmask_and_lt(&proc4430_state.ref_count,
OMAP4430PROC_MAKE_MAGICSTAMP(0),
OMAP4430PROC_MAKE_MAGICSTAMP(1))
== true) {
printk(KERN_ERR "proc4430_open failed "
"Module not initialized");
return -ENODEV;
}
/* Initialize return parameter handle. */
*handle_ptr = NULL;
......@@ -358,6 +437,16 @@ int proc4430_close(void *handle)
int retval = 0;
BUG_ON(handle == NULL);
if (atomic_cmpmask_and_lt(&proc4430_state.ref_count,
OMAP4430PROC_MAKE_MAGICSTAMP(0),
OMAP4430PROC_MAKE_MAGICSTAMP(1))
== true) {
printk(KERN_ERR "proc4430_close failed "
"Module not initialized");
return -ENODEV;
}
/* nothing to be done for now */
return retval;
}
......@@ -374,13 +463,36 @@ EXPORT_SYMBOL(proc4430_close);
int proc4430_attach(void *handle, struct processor_attach_params *params)
{
int retval = 0;
struct processor_object *proc_handle =
(struct processor_object *)handle;
struct processor_object *proc_handle = NULL;
struct proc4430_object *object = NULL;
u32 map_count = 0;
u32 i;
memory_map_info map_info;
if (atomic_cmpmask_and_lt(&proc4430_state.ref_count,
OMAP4430PROC_MAKE_MAGICSTAMP(0),
OMAP4430PROC_MAKE_MAGICSTAMP(1))
== true) {
printk(KERN_ERR "proc4430_attach failed "
"Module not initialized");
return -ENODEV;
}
if (WARN_ON(handle == NULL)) {
printk(KERN_ERR "proc4430_attach failed "
"Driver handle is NULL");
return -EINVAL;
}
if (WARN_ON(params == NULL)) {
printk(KERN_ERR "proc4430_attach failed "
"Argument processor_attach_params * is NULL");
return -EINVAL;
}
proc_handle = (struct processor_object *)handle;
object = (struct proc4430_object *)proc_handle->object;
/* Return memory information in params. */
for (i = 0; (i < object->params.num_mem_entries); i++) {
......@@ -390,7 +502,6 @@ int proc4430_attach(void *handle, struct processor_attach_params *params)
*/
if ((object->params.mem_entries[i].master_virt_addr == (u32)-1)
&& (object->params.mem_entries[i].shared == true)) {
map_count++;
map_info.src = object->params.mem_entries[i].phys_addr;
map_info.size = object->params.mem_entries[i].size;
map_info.is_cached = false;
......@@ -399,6 +510,7 @@ int proc4430_attach(void *handle, struct processor_attach_params *params)
printk(KERN_ERR "proc4430_attach failed\n");
return -EFAULT;
}
map_count++;
object->params.mem_entries[i].master_virt_addr =
map_info.dst;
params->mem_entries[i].addr
......@@ -428,12 +540,28 @@ int proc4430_attach(void *handle, struct processor_attach_params *params)
*/
int proc4430_detach(void *handle)
{
struct processor_object *proc_handle =
(struct processor_object *)handle;
struct processor_object *proc_handle = NULL;
struct proc4430_object *object = NULL;
u32 i;
memory_unmap_info unmap_info;
if (atomic_cmpmask_and_lt(&proc4430_state.ref_count,
OMAP4430PROC_MAKE_MAGICSTAMP(0),
OMAP4430PROC_MAKE_MAGICSTAMP(1))
== true) {
printk(KERN_ERR "proc4430_detach failed "
"Module not initialized");
return -ENODEV;
}
if (WARN_ON(handle == NULL)) {
printk(KERN_ERR "proc4430_attach failed "
"Argument Driverhandle is NULL");
return -EINVAL;
}
proc_handle = (struct processor_object *)handle;
object = (struct proc4430_object *)proc_handle->object;
for (i = 0; (i < object->params.num_mem_entries); i++) {
if ((object->params.mem_entries[i].master_virt_addr == (u32)-1)
......@@ -462,6 +590,23 @@ int proc4430_detach(void *handle)
int proc4430_start(void *handle, u32 entry_pt,
struct processor_start_params *start_params)
{
if (atomic_cmpmask_and_lt(&proc4430_state.ref_count,
OMAP4430PROC_MAKE_MAGICSTAMP(0),
OMAP4430PROC_MAKE_MAGICSTAMP(1))
== true) {
printk(KERN_ERR "proc4430_start failed "
"Module not initialized");
return -ENODEV;
}
/*FIXME: Remove handle and entry_pt if not used */
if (WARN_ON(start_params == NULL)) {
printk(KERN_ERR "proc4430_attach failed "
"Argument processor_start_params * is NULL");
return -EINVAL;
}
switch (start_params->params->proc_id) {
case SYS_M3:
/* De-assert RST2 */
......@@ -491,6 +636,15 @@ int proc4430_start(void *handle, u32 entry_pt,
int
proc4430_stop(void *handle)
{
if (atomic_cmpmask_and_lt(&proc4430_state.ref_count,
OMAP4430PROC_MAKE_MAGICSTAMP(0),
OMAP4430PROC_MAKE_MAGICSTAMP(1))
== true) {
printk(KERN_ERR "proc4430_stop failed "
"Module not initialized");
return -ENODEV;
}
/* Stoppping both SYS M3 and APP M3 */
/* FIX ME: this needs to be changed to handle reset
* of only APPM3 case too
......@@ -510,6 +664,15 @@ int proc4430_read(void *handle, u32 proc_addr, u32 *num_bytes,
void *buffer)
{
int retval = 0;
if (atomic_cmpmask_and_lt(&proc4430_state.ref_count,
OMAP4430PROC_MAKE_MAGICSTAMP(0),
OMAP4430PROC_MAKE_MAGICSTAMP(1))
== true) {
printk(KERN_ERR "proc4430_read failed "
"Module not initialized");
return -ENODEV;
}
/* TODO */
return retval;
}
......@@ -527,6 +690,15 @@ int proc4430_write(void *handle, u32 proc_addr, u32 *num_bytes,
{
int retval = 0;
if (atomic_cmpmask_and_lt(&proc4430_state.ref_count,
OMAP4430PROC_MAKE_MAGICSTAMP(0),
OMAP4430PROC_MAKE_MAGICSTAMP(1))
== true) {
printk(KERN_ERR "proc4430_write failed "
"Module not initialized");
return -ENODEV;
}
/* TODO */
return retval;
}
......@@ -542,6 +714,16 @@ int proc4430_control(void *handle, int cmd, void *arg)
{
int retval = 0;
/*FIXME: Remove handle,etc if not used */
if (atomic_cmpmask_and_lt(&proc4430_state.ref_count,
OMAP4430PROC_MAKE_MAGICSTAMP(0),
OMAP4430PROC_MAKE_MAGICSTAMP(1))
== true) {
printk(KERN_ERR "proc4430_control failed "
"Module not initialized");
return -ENODEV;
}
return retval;
}
......@@ -557,8 +739,7 @@ int proc4430_translate_addr(void *handle,
void *src_addr, enum proc_mgr_addr_type src_addr_type)
{
int retval = 0;
struct processor_object *proc_handle =
(struct processor_object *)handle;
struct processor_object *proc_handle = NULL;
struct proc4430_object *object = NULL;
struct proc4430_mem_entry *entry = NULL;
bool found = false;
......@@ -566,17 +747,38 @@ int proc4430_translate_addr(void *handle,
u32 to_addr_base = (u32)NULL;
u32 i;
if (WARN_ON(handle == NULL))
if (atomic_cmpmask_and_lt(&proc4430_state.ref_count,
OMAP4430PROC_MAKE_MAGICSTAMP(0),
OMAP4430PROC_MAKE_MAGICSTAMP(1))
== true) {
printk(KERN_ERR "proc4430_translate_addr failed "
"Module not initialized");
retval = -ENODEV;
goto error_exit;
if (WARN_ON(dst_addr == NULL))
}
if (WARN_ON(handle == NULL)) {
retval = -EINVAL;
goto error_exit;
if (WARN_ON(dst_addr_type > PROC_MGR_ADDRTYPE_ENDVALUE))
}
if (WARN_ON(dst_addr == NULL)) {
retval = -EINVAL;
goto error_exit;
if (WARN_ON(src_addr == NULL))
}
if (WARN_ON(dst_addr_type > PROC_MGR_ADDRTYPE_ENDVALUE)) {
retval = -EINVAL;
goto error_exit;
if (WARN_ON(src_addr_type > PROC_MGR_ADDRTYPE_ENDVALUE))
}
if (WARN_ON(src_addr == NULL)) {
retval = -EINVAL;
goto error_exit;
}
if (WARN_ON(src_addr_type > PROC_MGR_ADDRTYPE_ENDVALUE)) {
retval = -EINVAL;
goto error_exit;
}
proc_handle = (struct processor_object *)handle;
object = (struct proc4430_object *)proc_handle->object;
*dst_addr = NULL;
for (i = 0 ; i < object->params.num_mem_entries ; i++) {
......@@ -604,6 +806,7 @@ int proc4430_translate_addr(void *handle,
goto error_exit;
}
return 0;
error_exit:
return retval;
}
......@@ -624,6 +827,18 @@ int proc4430_map(void *handle, u32 proc_addr,
u32 va_align;
u32 size_align;
if (atomic_cmpmask_and_lt(&proc4430_state.ref_count,
OMAP4430PROC_MAKE_MAGICSTAMP(0),
OMAP4430PROC_MAKE_MAGICSTAMP(1))
== true) {
printk(KERN_ERR "proc4430_map failed "
"Module not initialized");
retval = -ENODEV;
goto error_exit;
}
/*FIXME: Remove handle,etc if not used */
/* FIX ME: Temporary work around until the dynamic memory mapping
* for Tiler address space is available
*/
......@@ -645,6 +860,8 @@ int proc4430_map(void *handle, u32 proc_addr,
/* Mapped address = MSB of DA | LSB of VA */
*mapped_addr = (da_align | (proc_addr & (PAGE_SIZE - 1)));
error_exit:
return retval;
}
......@@ -660,6 +877,18 @@ int proc4430_unmap(void *handle, u32 mapped_addr)
int ret_val = 0;
int size_align;
if (atomic_cmpmask_and_lt(&proc4430_state.ref_count,
OMAP4430PROC_MAKE_MAGICSTAMP(0),
OMAP4430PROC_MAKE_MAGICSTAMP(1))
== true) {
printk(KERN_ERR "proc4430_map failed "
"Module not initialized");
ret_val = -1;
goto error_exit;
}
/*FIXME: Remove handle,etc if not used */
da_align = PG_ALIGN_LOW((u32)mapped_addr, PAGE_SIZE);
ret_val = dmm_unreserve_memory(da_align, &size_align);
if (WARN_ON(ret_val < 0))
......@@ -668,6 +897,7 @@ int proc4430_unmap(void *handle, u32 mapped_addr)
if (WARN_ON(ret_val < 0))
goto error_exit;
return 0;
error_exit:
printk(KERN_WARNING "proc4430_unmap failed !!!!\n");
return ret_val;
......@@ -687,6 +917,16 @@ int proc4430_virt_to_phys(void *handle, u32 da, u32 *mapped_entries,
int i;
int ret_val = 0;
if (atomic_cmpmask_and_lt(&proc4430_state.ref_count,
OMAP4430PROC_MAKE_MAGICSTAMP(0),
OMAP4430PROC_MAKE_MAGICSTAMP(1))
== true) {
printk(KERN_ERR "proc4430_virt_to_phys failed "
"Module not initialized");
ret_val = -EFAULT;
goto error_exit;
}
if (handle == NULL || mapped_entries == NULL || num_of_entries == 0) {
ret_val = -EFAULT;
goto error_exit;
......@@ -697,6 +937,7 @@ int proc4430_virt_to_phys(void *handle, u32 da, u32 *mapped_entries,
da_align += PAGE_SIZE;
}
return 0;
error_exit:
printk(KERN_WARNING "proc4430_virtToPhys failed !!!!\n");
return ret_val;
......@@ -709,17 +950,27 @@ error_exit:
*/
int proc4430_proc_info(void *handle, struct proc_mgr_proc_info *procinfo)
{
struct processor_object *proc_handle =
(struct processor_object *)handle;
struct processor_object *proc_handle = NULL;
struct proc4430_object *object = NULL;
struct proc4430_mem_entry *entry = NULL;
int i;
if (atomic_cmpmask_and_lt(&proc4430_state.ref_count,
OMAP4430PROC_MAKE_MAGICSTAMP(0),
OMAP4430PROC_MAKE_MAGICSTAMP(1))
== true) {
printk(KERN_ERR "proc4430_proc_info failed "
"Module not initialized");
goto error_exit;
}
if (WARN_ON(handle == NULL))
goto error_exit;
if (WARN_ON(procinfo == NULL))
goto error_exit;
proc_handle = (struct processor_object *)handle;
object = (struct proc4430_object *)proc_handle->object;
for (i = 0 ; i < object->params.num_mem_entries ; i++) {
......@@ -733,6 +984,7 @@ int proc4430_proc_info(void *handle, struct proc_mgr_proc_info *procinfo)
procinfo->num_mem_entries = object->params.num_mem_entries;
procinfo->boot_mode = proc_handle->boot_mode;
return 0;
error_exit:
printk(KERN_WARNING "proc4430_proc_info failed !!!!\n");
return -EFAULT;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment