Revert "SDOCM00106428 Add notify mailbox driver support on DRA7xx (Part 3)"
[ipc/ipcdev.git] / packages / ti / sdo / ipc / family / vayu / InterruptArp32.xs
1 /*
2  * Copyright (c) 2012-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  */
32 /*
33  *  ======== InterruptArp32.xs ========
34  *
35  */
37 var Hwi         = null;
38 var Core        = null;
39 var MultiProc   = null;
40 var InterruptArp32       = null;
42 /*
43  *  ======== module$use ========
44  */
45 function module$use()
46 {
47     Hwi              = xdc.useModule("ti.sysbios.family.arp32.Hwi");
48     MultiProc        = xdc.useModule("ti.sdo.utils.MultiProc");
49     Ipc              = xdc.useModule("ti.sdo.ipc.Ipc");
50     InterruptArp32   = xdc.useModule("ti.sdo.ipc.family.vayu.InterruptArp32");
51     TableInit        = xdc.useModule("ti.sdo.ipc.family.vayu.TableInit");
53     /* Initialize procIdTable */
54     TableInit.initProcId(InterruptArp32);
56     /* Initialize mailboxTable */
57     TableInit.generateTable(InterruptArp32);
59     /* Initialize mailbox base address table */
60     this.mailboxBaseAddr[0]  = 0x4008B000;  /* EVE1 Internal Mailbox 0 */
61     this.mailboxBaseAddr[1]  = 0x4008C000;  /* EVE1 Internal Mailbox 1 */
62     this.mailboxBaseAddr[2]  = 0x4208D000;  /* EVE1 Internal Mailbox 2 */
63     this.mailboxBaseAddr[3]  = 0x4008B000;  /* EVE2 Internal Mailbox 0 */
64     this.mailboxBaseAddr[4]  = 0x4008C000;  /* EVE2 Internal Mailbox 1 */
65     this.mailboxBaseAddr[5]  = 0x4218D000;  /* EVE2 Internal Mailbox 2 */
66     this.mailboxBaseAddr[6]  = 0x4008B000;  /* EVE3 Internal Mailbox 0 */
67     this.mailboxBaseAddr[7]  = 0x4008C000;  /* EVE3 Internal Mailbox 1 */
68     this.mailboxBaseAddr[8]  = 0x4228D000;  /* EVE3 Internal Mailbox 2 */
69     this.mailboxBaseAddr[9]  = 0x4008B000;  /* EVE4 Internal Mailbox 0 */
70     this.mailboxBaseAddr[10] = 0x4008C000;  /* EVE4 Internal Mailbox 1 */
71     this.mailboxBaseAddr[11] = 0x4238D000;  /* EVE4 Internal Mailbox 2 */
72     this.mailboxBaseAddr[12] = 0x48840000;  /* System Mailbox 5 */
73     this.mailboxBaseAddr[13] = 0x48842000;  /* System Mailbox 6 */
74     this.mailboxBaseAddr[14] = 0x48844000;  /* System Mailbox 7 */
75     this.mailboxBaseAddr[15] = 0x48846000;  /* System Mailbox 8 */
77     /* each EVE receives its message using the local mailbox address */
78     if (MultiProc.id == this.eve1ProcId) {
79         this.mailboxBaseAddr[2] = 0x4008D000;
80     }
81     else if (MultiProc.id == this.eve2ProcId) {
82         this.mailboxBaseAddr[5] = 0x4008D000;
83     }
84     else if (MultiProc.id == this.eve3ProcId) {
85         this.mailboxBaseAddr[8] = 0x4008D000;
86     }
87     else if (MultiProc.id == this.eve4ProcId) {
88         this.mailboxBaseAddr[11] = 0x4008D000;
89     }
91     /* EVE interrupt mapping. See EVE28 functional specs */
92     this.eveInterruptTable[0] = 60;  /* EVE1 - Group1/INTC1 */
93     this.eveInterruptTable[1] = 60;  /* EVE2 - Group1/INTC1 */
94     this.eveInterruptTable[2] = 60;  /* EVE3 - Group1/INTC1 */
95     this.eveInterruptTable[3] = 60;  /* EVE4 - Group1/INTC1 */
96     this.eveInterruptTable[4] = 29;  /* DSP1 - Group0/INTC0 */
97     this.eveInterruptTable[5] = 30;  /* DSP2 - Group0/INTC0 */
98     this.eveInterruptTable[6] = 29;  /* IPU1-0 */
99     this.eveInterruptTable[7] = 30;  /* IPU2-0 */
100     this.eveInterruptTable[8] = 29;  /* HOST */
101     this.eveInterruptTable[9] = 30;  /* IPU1-1 */
102     this.eveInterruptTable[10] = 30; /* IPU2-1 */
104     /*
105      * In case of a spec change, follow the process shown below:
106      * 1. Update the mailboxBaseAddr Table.
107      * 2. Update the dspInterruptTable.
108      * 3. Update Virtual Index assignment.
109      * 4. Update NUMCORES, NUMEVES and EVEMBX2BASEIDX variables
110      *    in order to correctly intialize the mailboxTable.
111      */
114 /*
115  *  ======== module$static$init ========
116  *  Initialize module values.
117  */
118 function module$static$init(mod, params)
120     var idx;
121     var remoteProcId;
123     for (remoteProcId=0; remoteProcId < InterruptArp32.procIdTable.length; remoteProcId++) {
124         mod.fxnTable[remoteProcId].func  = null;
125         mod.fxnTable[remoteProcId].arg   = 0;
126     }
128     for (idx = 0; idx < (InterruptArp32.NUM_EVE_MBX/InterruptArp32.NUM_EVES); idx++) {
129         mod.numPlugged[idx] = 0;
130     }