8e55a3dd1db320d464212afe1b2ee1288a4fe7d6
[ipc/ipcdev.git] / packages / ti / ipc / mm / MmServiceMgr.c
1 /*
2  * Copyright (c) 2013, Texas Instruments Incorporated
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  *
9  * *  Redistributions of source code must retain the above copyright
10  *    notice, this list of conditions and the following disclaimer.
11  *
12  * *  Redistributions in binary form must reproduce the above copyright
13  *    notice, this list of conditions and the following disclaimer in the
14  *    documentation and/or other materials provided with the distribution.
15  *
16  * *  Neither the name of Texas Instruments Incorporated nor the names of
17  *    its contributors may be used to endorse or promote products derived
18  *    from this software without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
22  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
23  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
24  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
25  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
26  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
27  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
28  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
29  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
30  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31  */
33 /*
34  *  ======== MmServiceMgr.c ========
35  */
37 #include <string.h>
39 #include <xdc/std.h>
40 #include <xdc/runtime/Memory.h>
41 #include <xdc/runtime/System.h>
43 #include <ti/grcm/RcmServer.h>
44 #include <ti/ipc/MultiProc.h>
45 #include <ti/ipc/mm/MmType.h>
46 #include <ti/srvmgr/ServiceMgr.h>
47 #include <ti/srvmgr/omaprpc/OmapRpc.h>
49 #include "MmServiceMgr.h"
51 #define MmServiceMgr_PORT (59)
53 typedef struct {
54     RcmServer_Params    rcmParams;
55     Int                 aryLen;
56     OmapRpc_FuncSignature *sigAry;
57 } MmServiceMgr_Client;
59 static Int MmServiceMgr_ref = 0;
61 /* temporary: needs to be removed */
62 extern Int32 OmapRpc_GetSvrMgrHandle(Void *srvc, Int32 num, Int32 *params);
64 /*
65  *  ======== MmServiceMgr_init ========
66  */
67 Int MmServiceMgr_init(Void)
68 {
69     if (MmServiceMgr_ref++ != 0) {
70         return(MmServiceMgr_S_SUCCESS); /* module already initialized */
71     }
73     RcmServer_init();
74 /*  ServiceMgr_init(); */
76     return(MmServiceMgr_S_SUCCESS);
77 }
79 /*
80  *  ======== MmServiceMgr_exit ========
81  */
82 Void MmServiceMgr_exit(Void)
83 {
84     if (--MmServiceMgr_ref != 0) {
85         return; /* module still in use */
86     }
88     RcmServer_exit();
89 }
91 /*
92  *  ======== MmServiceMgr_register ========
93  */
94 Int MmServiceMgr_register(const String name, RcmServer_Params *rcmParams,
95         MmType_FxnSigTab *fxnSigTab, MmServiceMgr_DelFxn delFxn)
96 {
97 #if 1
98     Int status = MmServiceMgr_S_SUCCESS;
99     OmapRpc_Handle handle;
101     handle = OmapRpc_createChannel(name, MultiProc_getId("HOST"),
102             MmServiceMgr_PORT, rcmParams, fxnSigTab, delFxn);
104     if (handle == NULL) {
105         status = MmServiceMgr_E_FAIL;
106     }
108     return(status);
109 #else
110     Int status = MmServiceMgr_S_SUCCESS;
111     MmServiceMgr_Client *obj;
112     RcmServer_FxnDesc *fxnAry;
113     Int func;
115     System_printf("MmServiceMgr_register: -->\n");
117     obj = Memory_calloc(NULL, sizeof(MmServiceMgr_Client), 0, NULL);
119     if (obj == NULL) {
120         System_printf("MmServiceMgr_register: Error: out of memory\n");
121         status = MmServiceMgr_E_FAIL;
122         goto leave;
123     }
125     /* Temporary: make a local copy of server create params in order
126      * to add one more function to the function table. Will be removed.
127      */
128     memcpy(&obj->rcmParams, rcmParams, sizeof(RcmServer_Params));
129     obj->rcmParams.fxns.length = rcmParams->fxns.length + 1;
131     obj->rcmParams.fxns.elem = Memory_calloc(NULL, obj->rcmParams.fxns.length *
132             sizeof(RcmServer_FxnDesc), 0, NULL);
134     if (obj->rcmParams.fxns.elem == NULL) {
135         System_printf("MmServiceMgr_register: Error: out of memory\n");
136         status = MmServiceMgr_E_FAIL;
137         goto leave;
138     }
140     /* Temporary: make a local copy of signature array in order
141      * to add the "first function" signature. Will be removed.
142      */
143     obj->aryLen = aryLen + 1;
145     obj->sigAry = Memory_calloc(NULL, obj->aryLen *
146             sizeof(OmapRpc_FuncSignature), 0, NULL);
148     if (obj->sigAry == NULL) {
149         System_printf("MmServiceMgr_register: Error: out of memory\n");
150         status = MmServiceMgr_E_FAIL;
151         goto leave;
152     }
154     /* Temporary: insert the "first function" in slot 0, then copy
155      * in the caller's functions. Eventually, the create function will be
156      * removed.
157      */
158     obj->rcmParams.fxns.elem[0].name =
159             OmapRpc_Stringerize(OmapRpc_GetSvrMgrHandle);
160     obj->rcmParams.fxns.elem[0].addr.createFxn =
161             (RcmServer_MsgCreateFxn)OmapRpc_GetSvrMgrHandle;
162     strncpy(obj->sigAry[0].name, obj->rcmParams.fxns.elem[0].name,
163             OMAPRPC_MAX_CHANNEL_NAMELEN);
164     obj->sigAry[0].numParam = 0;
166     fxnAry = rcmParams->fxns.elem;
168     for (func = 0; func < rcmParams->fxns.length; func++) {
169         obj->rcmParams.fxns.elem[func+1].name = fxnAry[func].name;
170         obj->rcmParams.fxns.elem[func+1].addr.fxn = fxnAry[func].addr.fxn;
172         memcpy(&obj->sigAry[func+1], &sigAry[func],
173                 sizeof(OmapRpc_FuncSignature));
174     }
176     if (!ServiceMgr_register(name, &obj->rcmParams)) {
177         System_printf("MmServiceMgr_register: Error: service register failed, "
178                 "status=%d\n");
179         status = MmServiceMgr_E_FAIL;
180         goto leave;
181     }
183 leave:
184     if (status < 0) {
185         if ((obj != NULL) && (obj->sigAry != NULL)) {
186             Memory_free(NULL, obj->sigAry,
187                     obj->aryLen * sizeof(OmapRpc_FuncDeclaration));
188         }
189         if ((obj != NULL) && (obj->rcmParams.fxns.elem != NULL)) {
190             Memory_free(NULL, obj->rcmParams.fxns.elem,
191                     obj->rcmParams.fxns.length * sizeof(RcmServer_FxnDesc));
192         }
193         if (obj != NULL) {
194             Memory_free(NULL, obj, sizeof(MmServiceMgr_Client));
195         }
196     }
198     System_printf("MmServiceMgr_register: <--, status=%d\n", status);
199     return(status);
200 #endif
203 #if 0
204 /*
205  *  ======== MmServiceMgr_start ========
206  */
207 Int MmServiceMgr_start(const String name, Int aryLen,
208         OmapRpc_FuncSignature *sigAry)
210     extern Int OmapRpc_start(const String name, Int port, Int aryLen,
211         OmapRpc_FuncSignature *sigAry);
213     Int status = MmServiceMgr_S_SUCCESS;
215     OmapRpc_start(name, MmServiceMgr_PORT, aryLen, sigAry);
217     return(status);
219 #endif