Commit 2ab57348 authored by Fernando Guzman Lugo's avatar Fernando Guzman Lugo Committed by Greg Kroah-Hartman

staging: tidspbridge - remove dmm custom module

Dmm custom module is not needed anymore.
Signed-off-by: default avatarFernando Guzman Lugo <x0095840@ti.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent b1ced160
...@@ -5,7 +5,7 @@ libcore = core/chnl_sm.o core/msg_sm.o core/io_sm.o core/tiomap3430.o \ ...@@ -5,7 +5,7 @@ libcore = core/chnl_sm.o core/msg_sm.o core/io_sm.o core/tiomap3430.o \
core/tiomap3430_pwr.o core/tiomap_io.o core/dsp-mmu.o \ core/tiomap3430_pwr.o core/tiomap_io.o core/dsp-mmu.o \
core/ue_deh.o core/wdt.o core/dsp-clock.o core/sync.o core/ue_deh.o core/wdt.o core/dsp-clock.o core/sync.o
libpmgr = pmgr/chnl.o pmgr/io.o pmgr/msg.o pmgr/cod.o pmgr/dev.o pmgr/dspapi.o \ libpmgr = pmgr/chnl.o pmgr/io.o pmgr/msg.o pmgr/cod.o pmgr/dev.o pmgr/dspapi.o \
pmgr/dmm.o pmgr/cmm.o pmgr/dbll.o pmgr/cmm.o pmgr/dbll.o
librmgr = rmgr/dbdcd.o rmgr/disp.o rmgr/drv.o rmgr/mgr.o rmgr/node.o \ librmgr = rmgr/dbdcd.o rmgr/disp.o rmgr/drv.o rmgr/mgr.o rmgr/node.o \
rmgr/proc.o rmgr/pwr.o rmgr/rmm.o rmgr/strm.o rmgr/dspdrv.o \ rmgr/proc.o rmgr/pwr.o rmgr/rmm.o rmgr/strm.o rmgr/dspdrv.o \
rmgr/nldr.o rmgr/drv_interface.o rmgr/nldr.o rmgr/drv_interface.o
......
...@@ -47,7 +47,6 @@ ...@@ -47,7 +47,6 @@
/* ----------------------------------- Platform Manager */ /* ----------------------------------- Platform Manager */
#include <dspbridge/dev.h> #include <dspbridge/dev.h>
#include <dspbridge/dspapi.h> #include <dspbridge/dspapi.h>
#include <dspbridge/dmm.h>
#include <dspbridge/wdt.h> #include <dspbridge/wdt.h>
/* ----------------------------------- Local */ /* ----------------------------------- Local */
......
...@@ -27,7 +27,6 @@ ...@@ -27,7 +27,6 @@
#include <dspbridge/nodedefs.h> #include <dspbridge/nodedefs.h>
#include <dspbridge/dispdefs.h> #include <dspbridge/dispdefs.h>
#include <dspbridge/dspdefs.h> #include <dspbridge/dspdefs.h>
#include <dspbridge/dmm.h>
#include <dspbridge/host_os.h> #include <dspbridge/host_os.h>
/* ----------------------------------- This */ /* ----------------------------------- This */
...@@ -233,29 +232,6 @@ extern int dev_get_chnl_mgr(struct dev_object *hdev_obj, ...@@ -233,29 +232,6 @@ extern int dev_get_chnl_mgr(struct dev_object *hdev_obj,
extern int dev_get_cmm_mgr(struct dev_object *hdev_obj, extern int dev_get_cmm_mgr(struct dev_object *hdev_obj,
struct cmm_object **mgr); struct cmm_object **mgr);
/*
* ======== dev_get_dmm_mgr ========
* Purpose:
* Retrieve the handle to the dynamic memory manager created for this
* device.
* Parameters:
* hdev_obj: Handle to device object created with
* dev_create_device().
* *mgr: Ptr to location to store handle.
* Returns:
* 0: Success.
* -EFAULT: Invalid hdev_obj.
* Requires:
* mgr != NULL.
* DEV Initialized.
* Ensures:
* 0: *mgr contains a handle to a channel manager object,
* or NULL.
* else: *mgr is NULL.
*/
extern int dev_get_dmm_mgr(struct dev_object *hdev_obj,
struct dmm_object **mgr);
/* /*
* ======== dev_get_cod_mgr ======== * ======== dev_get_cod_mgr ========
* Purpose: * Purpose:
......
/*
* dmm.h
*
* DSP-BIOS Bridge driver support functions for TI OMAP processors.
*
* The Dynamic Memory Mapping(DMM) module manages the DSP Virtual address
* space that can be directly mapped to any MPU buffer or memory region.
*
* Copyright (C) 2005-2006 Texas Instruments, Inc.
*
* This package 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.
*
* THIS PACKAGE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
* WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
*/
#ifndef DMM_
#define DMM_
#include <dspbridge/dbdefs.h>
struct dmm_object;
/* DMM attributes used in dmm_create() */
struct dmm_mgrattrs {
u32 reserved;
};
#define DMMPOOLSIZE 0x4000000
/*
* ======== dmm_get_handle ========
* Purpose:
* Return the dynamic memory manager object for this device.
* This is typically called from the client process.
*/
extern int dmm_get_handle(void *hprocessor,
struct dmm_object **dmm_manager);
extern int dmm_reserve_memory(struct dmm_object *dmm_mgr,
u32 size, u32 *prsv_addr);
extern int dmm_un_reserve_memory(struct dmm_object *dmm_mgr,
u32 rsv_addr);
extern int dmm_map_memory(struct dmm_object *dmm_mgr, u32 addr,
u32 size);
extern int dmm_un_map_memory(struct dmm_object *dmm_mgr,
u32 addr, u32 *psize);
extern int dmm_destroy(struct dmm_object *dmm_mgr);
extern int dmm_delete_tables(struct dmm_object *dmm_mgr);
extern int dmm_create(struct dmm_object **dmm_manager,
struct dev_object *hdev_obj,
const struct dmm_mgrattrs *mgr_attrts);
extern bool dmm_init(void);
extern void dmm_exit(void);
extern int dmm_create_tables(struct dmm_object *dmm_mgr,
u32 addr, u32 size);
#ifdef DSP_DMM_DEBUG
u32 dmm_mem_map_dump(struct dmm_object *dmm_mgr);
#endif
#endif /* DMM_ */
...@@ -108,12 +108,6 @@ struct dmm_map_object { ...@@ -108,12 +108,6 @@ struct dmm_map_object {
struct bridge_dma_map_info dma_info; struct bridge_dma_map_info dma_info;
}; };
/* Used for DMM reserved memory accounting */
struct dmm_rsv_object {
struct list_head link;
u32 dsp_reserved_addr;
};
/* New structure (member of process context) abstracts DMM resource info */ /* New structure (member of process context) abstracts DMM resource info */
struct dspheap_res_object { struct dspheap_res_object {
s32 heap_allocated; /* DMM status */ s32 heap_allocated; /* DMM status */
......
...@@ -34,7 +34,6 @@ ...@@ -34,7 +34,6 @@
#include <dspbridge/cod.h> #include <dspbridge/cod.h>
#include <dspbridge/drv.h> #include <dspbridge/drv.h>
#include <dspbridge/proc.h> #include <dspbridge/proc.h>
#include <dspbridge/dmm.h>
/* ----------------------------------- Resource Manager */ /* ----------------------------------- Resource Manager */
#include <dspbridge/mgr.h> #include <dspbridge/mgr.h>
...@@ -75,7 +74,6 @@ struct dev_object { ...@@ -75,7 +74,6 @@ struct dev_object {
struct msg_mgr *hmsg_mgr; /* Message manager. */ struct msg_mgr *hmsg_mgr; /* Message manager. */
struct io_mgr *hio_mgr; /* IO manager (CHNL, msg_ctrl) */ struct io_mgr *hio_mgr; /* IO manager (CHNL, msg_ctrl) */
struct cmm_object *hcmm_mgr; /* SM memory manager. */ struct cmm_object *hcmm_mgr; /* SM memory manager. */
struct dmm_object *dmm_mgr; /* Dynamic memory manager. */
struct ldr_module *module_obj; /* Bridge Module handle. */ struct ldr_module *module_obj; /* Bridge Module handle. */
u32 word_size; /* DSP word size: quick access. */ u32 word_size; /* DSP word size: quick access. */
struct drv_object *hdrv_obj; /* Driver Object */ struct drv_object *hdrv_obj; /* Driver Object */
...@@ -250,9 +248,6 @@ int dev_create_device(struct dev_object **device_obj, ...@@ -250,9 +248,6 @@ int dev_create_device(struct dev_object **device_obj,
/* Instantiate the DEH module */ /* Instantiate the DEH module */
status = bridge_deh_create(&dev_obj->hdeh_mgr, dev_obj); status = bridge_deh_create(&dev_obj->hdeh_mgr, dev_obj);
} }
/* Create DMM mgr . */
status = dmm_create(&dev_obj->dmm_mgr,
(struct dev_object *)dev_obj, NULL);
} }
/* Add the new DEV_Object to the global list: */ /* Add the new DEV_Object to the global list: */
if (!status) { if (!status) {
...@@ -278,8 +273,6 @@ int dev_create_device(struct dev_object **device_obj, ...@@ -278,8 +273,6 @@ int dev_create_device(struct dev_object **device_obj,
kfree(dev_obj->proc_list); kfree(dev_obj->proc_list);
if (dev_obj->cod_mgr) if (dev_obj->cod_mgr)
cod_delete(dev_obj->cod_mgr); cod_delete(dev_obj->cod_mgr);
if (dev_obj->dmm_mgr)
dmm_destroy(dev_obj->dmm_mgr);
kfree(dev_obj); kfree(dev_obj);
} }
...@@ -389,11 +382,6 @@ int dev_destroy_device(struct dev_object *hdev_obj) ...@@ -389,11 +382,6 @@ int dev_destroy_device(struct dev_object *hdev_obj)
dev_obj->hcmm_mgr = NULL; dev_obj->hcmm_mgr = NULL;
} }
if (dev_obj->dmm_mgr) {
dmm_destroy(dev_obj->dmm_mgr);
dev_obj->dmm_mgr = NULL;
}
/* Call the driver's bridge_dev_destroy() function: */ /* Call the driver's bridge_dev_destroy() function: */
/* Require of DevDestroy */ /* Require of DevDestroy */
if (dev_obj->hbridge_context) { if (dev_obj->hbridge_context) {
...@@ -473,32 +461,6 @@ int dev_get_cmm_mgr(struct dev_object *hdev_obj, ...@@ -473,32 +461,6 @@ int dev_get_cmm_mgr(struct dev_object *hdev_obj,
return status; return status;
} }
/*
* ======== dev_get_dmm_mgr ========
* Purpose:
* Retrieve the handle to the dynamic memory manager created for this
* device.
*/
int dev_get_dmm_mgr(struct dev_object *hdev_obj,
struct dmm_object **mgr)
{
int status = 0;
struct dev_object *dev_obj = hdev_obj;
DBC_REQUIRE(refs > 0);
DBC_REQUIRE(mgr != NULL);
if (hdev_obj) {
*mgr = dev_obj->dmm_mgr;
} else {
*mgr = NULL;
status = -EFAULT;
}
DBC_ENSURE(!status || (mgr != NULL && *mgr == NULL));
return status;
}
/* /*
* ======== dev_get_cod_mgr ======== * ======== dev_get_cod_mgr ========
* Purpose: * Purpose:
...@@ -751,10 +713,8 @@ void dev_exit(void) ...@@ -751,10 +713,8 @@ void dev_exit(void)
refs--; refs--;
if (refs == 0) { if (refs == 0)
cmm_exit(); cmm_exit();
dmm_exit();
}
DBC_ENSURE(refs >= 0); DBC_ENSURE(refs >= 0);
} }
...@@ -766,25 +726,12 @@ void dev_exit(void) ...@@ -766,25 +726,12 @@ void dev_exit(void)
*/ */
bool dev_init(void) bool dev_init(void)
{ {
bool cmm_ret, dmm_ret, ret = true; bool ret = true;
DBC_REQUIRE(refs >= 0); DBC_REQUIRE(refs >= 0);
if (refs == 0) { if (refs == 0)
cmm_ret = cmm_init(); ret = cmm_init();
dmm_ret = dmm_init();
ret = cmm_ret && dmm_ret;
if (!ret) {
if (cmm_ret)
cmm_exit();
if (dmm_ret)
dmm_exit();
}
}
if (ret) if (ret)
refs++; refs++;
......
This diff is collapsed.
...@@ -56,7 +56,6 @@ ...@@ -56,7 +56,6 @@
/* ----------------------------------- This */ /* ----------------------------------- This */
#include <dspbridge/nodepriv.h> #include <dspbridge/nodepriv.h>
#include <dspbridge/node.h> #include <dspbridge/node.h>
#include <dspbridge/dmm.h>
/* Static/Dynamic Loader includes */ /* Static/Dynamic Loader includes */
#include <dspbridge/dbll.h> #include <dspbridge/dbll.h>
...@@ -317,10 +316,6 @@ int node_allocate(struct proc_object *hprocessor, ...@@ -317,10 +316,6 @@ int node_allocate(struct proc_object *hprocessor,
u32 mapped_addr = 0; u32 mapped_addr = 0;
u32 map_attrs = 0x0; u32 map_attrs = 0x0;
struct dsp_processorstate proc_state; struct dsp_processorstate proc_state;
#ifdef DSP_DMM_DEBUG
struct dmm_object *dmm_mgr;
struct proc_object *p_proc_object = (struct proc_object *)hprocessor;
#endif
void *node_res; void *node_res;
...@@ -430,16 +425,6 @@ int node_allocate(struct proc_object *hprocessor, ...@@ -430,16 +425,6 @@ int node_allocate(struct proc_object *hprocessor,
if (status) if (status)
goto func_cont; goto func_cont;
#ifdef DSP_DMM_DEBUG
status = dmm_get_handle(p_proc_object, &dmm_mgr);
if (!dmm_mgr) {
status = DSP_EHANDLE;
goto func_cont;
}
dmm_mem_map_dump(dmm_mgr);
#endif
map_attrs |= DSP_MAPLITTLEENDIAN; map_attrs |= DSP_MAPLITTLEENDIAN;
map_attrs |= DSP_MAPELEMSIZE32; map_attrs |= DSP_MAPELEMSIZE32;
map_attrs |= DSP_MAPVIRTUALADDR; map_attrs |= DSP_MAPVIRTUALADDR;
...@@ -2499,11 +2484,7 @@ static void delete_node(struct node_object *hnode, ...@@ -2499,11 +2484,7 @@ static void delete_node(struct node_object *hnode,
struct stream_chnl stream; struct stream_chnl stream;
struct node_msgargs node_msg_args; struct node_msgargs node_msg_args;
struct node_taskargs task_arg_obj; struct node_taskargs task_arg_obj;
#ifdef DSP_DMM_DEBUG
struct dmm_object *dmm_mgr;
struct proc_object *p_proc_object =
(struct proc_object *)hnode->hprocessor;
#endif
int status; int status;
if (!hnode) if (!hnode)
goto func_end; goto func_end;
...@@ -2564,13 +2545,6 @@ static void delete_node(struct node_object *hnode, ...@@ -2564,13 +2545,6 @@ static void delete_node(struct node_object *hnode,
status = proc_un_map(hnode->hprocessor, (void *) status = proc_un_map(hnode->hprocessor, (void *)
task_arg_obj.udsp_heap_addr, task_arg_obj.udsp_heap_addr,
pr_ctxt); pr_ctxt);
#ifdef DSP_DMM_DEBUG
status = dmm_get_handle(p_proc_object, &dmm_mgr);
if (dmm_mgr)
dmm_mem_map_dump(dmm_mgr);
else
status = DSP_EHANDLE;
#endif
} }
} }
if (node_type != NODE_MESSAGE) { if (node_type != NODE_MESSAGE) {
......
...@@ -39,7 +39,6 @@ ...@@ -39,7 +39,6 @@
#include <dspbridge/cod.h> #include <dspbridge/cod.h>
#include <dspbridge/dev.h> #include <dspbridge/dev.h>
#include <dspbridge/procpriv.h> #include <dspbridge/procpriv.h>
#include <dspbridge/dmm.h>
/* ----------------------------------- Resource Manager */ /* ----------------------------------- Resource Manager */
#include <dspbridge/mgr.h> #include <dspbridge/mgr.h>
...@@ -1078,7 +1077,6 @@ int proc_load(void *hprocessor, const s32 argc_index, ...@@ -1078,7 +1077,6 @@ int proc_load(void *hprocessor, const s32 argc_index,
s32 cnew_envp; /* " " in new_envp[] */ s32 cnew_envp; /* " " in new_envp[] */
s32 nproc_id = 0; /* Anticipate MP version. */ s32 nproc_id = 0; /* Anticipate MP version. */
struct dcd_manager *hdcd_handle; struct dcd_manager *hdcd_handle;
struct dmm_object *dmm_mgr;
u32 dw_ext_end; u32 dw_ext_end;
u32 proc_id; u32 proc_id;
int brd_state; int brd_state;
...@@ -1269,25 +1267,6 @@ int proc_load(void *hprocessor, const s32 argc_index, ...@@ -1269,25 +1267,6 @@ int proc_load(void *hprocessor, const s32 argc_index,
if (!status) if (!status)
status = cod_get_sym_value(cod_mgr, EXTEND, status = cod_get_sym_value(cod_mgr, EXTEND,
&dw_ext_end); &dw_ext_end);
/* Reset DMM structs and add an initial free chunk */
if (!status) {
status =
dev_get_dmm_mgr(p_proc_object->hdev_obj,
&dmm_mgr);
if (dmm_mgr) {
/* Set dw_ext_end to DMM START u8
* address */
dw_ext_end =
(dw_ext_end + 1) * DSPWORDSIZE;
/* DMM memory is from EXT_END */
status = dmm_create_tables(dmm_mgr,
dw_ext_end,
DMMPOOLSIZE);
} else {
status = -EFAULT;
}
}
} }
} }
/* Restore the original argv[0] */ /* Restore the original argv[0] */
...@@ -1390,7 +1369,6 @@ int proc_map(void *hprocessor, void *pmpu_addr, u32 ul_size, ...@@ -1390,7 +1369,6 @@ int proc_map(void *hprocessor, void *pmpu_addr, u32 ul_size,
map_obj->dsp_addr = (va_align | map_obj->dsp_addr = (va_align |
((u32)pmpu_addr & (PG_SIZE4K - 1))); ((u32)pmpu_addr & (PG_SIZE4K - 1)));
*pp_map_addr = (void *)map_obj->dsp_addr; *pp_map_addr = (void *)map_obj->dsp_addr;
pr_err("%s: mapped address %x\n", __func__, *pp_map_addr);
} else { } else {
remove_mapping_information(pr_ctxt, va_align); remove_mapping_information(pr_ctxt, va_align);
} }
...@@ -1633,7 +1611,6 @@ int proc_un_map(void *hprocessor, void *map_addr, ...@@ -1633,7 +1611,6 @@ int proc_un_map(void *hprocessor, void *map_addr,
int status = 0; int status = 0;
struct proc_object *p_proc_object = (struct proc_object *)hprocessor; struct proc_object *p_proc_object = (struct proc_object *)hprocessor;
u32 va_align; u32 va_align;
u32 size_align;
va_align = PG_ALIGN_LOW((u32) map_addr, PG_SIZE4K); va_align = PG_ALIGN_LOW((u32) map_addr, PG_SIZE4K);
if (!p_proc_object) { if (!p_proc_object) {
......
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