787964c5a980530682edcddf02f0c6cf8cd5cecb
[ipc/ipcdev.git] / packages / ti / sdo / ipc / family / vayu / InterruptDsp.xs
1 /*
2  * Copyright (c) 2012-2014 Texas Instruments Incorporated - http://www.ti.com
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  *  ======== InterruptDsp.xs ========
35  */
36 var InterruptDsp = null;
38 /*
39  *  ======== module$use ========
40  */
41 function module$use()
42 {
43     /* load modules needed in meta domain and in target domain */
44     var TableInit = xdc.useModule("ti.sdo.ipc.family.vayu.TableInit");
45     InterruptDsp = this;
46     xdc.useModule('xdc.runtime.Assert');
47     xdc.useModule('xdc.runtime.Startup');
48     xdc.useModule('ti.sysbios.family.c64p.EventCombiner');
49     xdc.useModule('ti.sysbios.family.c64p.Hwi');
50     xdc.useModule('ti.sysbios.family.shared.vayu.IntXbar');
51     xdc.useModule('ti.sdo.ipc.Ipc');
52     xdc.useModule('ti.sdo.ipc.family.vayu.NotifySetup');
53     xdc.useModule('ti.sdo.ipc.notifyDrivers.IInterrupt');
54     xdc.useModule('ti.sdo.utils.MultiProc');
56     /* Initialize procIdTable */
57     TableInit.initProcId(InterruptDsp);
59     /* Initialize mailboxTable */
60     TableInit.generateTable(InterruptDsp);
62     /* Initialize mailbox base address table */
63     this.mailboxBaseAddr[0]  = 0x4208B000;  /* EVE1 Internal Mailbox 0 */
64     this.mailboxBaseAddr[1]  = 0x4208C000;  /* EVE1 Internal Mailbox 1 */
65     this.mailboxBaseAddr[2]  = 0x4208D000;  /* EVE1 Internal Mailbox 2 */
66     this.mailboxBaseAddr[3]  = 0x4218B000;  /* EVE2 Internal Mailbox 0 */
67     this.mailboxBaseAddr[4]  = 0x4218C000;  /* EVE2 Internal Mailbox 1 */
68     this.mailboxBaseAddr[5]  = 0x4218D000;  /* EVE2 Internal Mailbox 2 */
69     this.mailboxBaseAddr[6]  = 0x4228B000;  /* EVE3 Internal Mailbox 0 */
70     this.mailboxBaseAddr[7]  = 0x4228C000;  /* EVE3 Internal Mailbox 1 */
71     this.mailboxBaseAddr[8]  = 0x4228D000;  /* EVE3 Internal Mailbox 2 */
72     this.mailboxBaseAddr[9]  = 0x4238B000;  /* EVE4 Internal Mailbox 0 */
73     this.mailboxBaseAddr[10] = 0x4238C000;  /* EVE4 Internal Mailbox 1 */
74     this.mailboxBaseAddr[11] = 0x4238D000;  /* EVE4 Internal Mailbox 2 */
75     this.mailboxBaseAddr[12] = 0x48840000;  /* System Mailbox 5 */
76     this.mailboxBaseAddr[13] = 0x48842000;  /* System Mailbox 6 */
77     this.mailboxBaseAddr[14] = 0x48844000;  /* System Mailbox 7 */
78     this.mailboxBaseAddr[15] = 0x48846000;  /* System Mailbox 8 */
80     /*
81      * In case of a spec change, follow the process shown below:
82      * 1. Update the mailboxBaseAddr Table.
83      * 2. Update the dspInterruptTable.
84      * 3. Update Virtual Index assignment.
85      * 4. Update NUMCORES, NUMEVES and EVEMBX2BASEIDX variables
86      *    in order to correctly intialize the mailboxTable.
87      */
88 }
90 function module$static$init(mod, params)
91 {
92     var remoteProcId;
93     var idx;
95     for (remoteProcId = 0; remoteProcId < InterruptDsp.procIdTable.length;
96         remoteProcId++) {
97         mod.fxnTable[remoteProcId].func  = null;
98         mod.fxnTable[remoteProcId].arg   = 0;
99     }
101     /* Initialize Interrupt Event Ids for communicating with this processor */
102     mod.interruptTable[0] = 55; /* EVE1 -> DSP1 or DSP2 */
103     mod.interruptTable[1] = 56; /* EVE2 -> DSP1 or DSP2 */
104     mod.interruptTable[2] = 58; /* EVE3 -> DSP1 or DSP2 */
105     mod.interruptTable[3] = 59; /* EVE4 -> DSP1 or DSP2 */
106     mod.interruptTable[4] = 60; /* DSP1 -> DSP2 */
107     mod.interruptTable[5] = 60; /* DSP2 -> DSP1 */
108     mod.interruptTable[8] = 57; /* HOST -> DSP1 or DSP2 */
110     /* These are not known at config time and is set a runtime */
111     mod.interruptTable[6] = 0; /* IPU1 -> DSP1 or DSP2 */
112     mod.interruptTable[7] = 0; /* IPU2 -> DSP1 or DSP2 */
113     mod.interruptTable[9] = 0; /* IPU1-1 -> DSP1 or DSP2 */
114     mod.interruptTable[10] = 0; /* IPU2-1 -> DSP1 or DSP2 */