]> Gitweb @ Texas Instruments - Open Source Git Repositories - git.TI.com/gitweb - ipc/ipcdev.git/blob - src/ti/sdo/ipc/family/ti81xx/InterruptDsp.xs
f6c8fa0a0e6795f76a42c5642424a66a47d59165
[ipc/ipcdev.git] / src / ti / sdo / ipc / family / ti81xx / InterruptDsp.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  *  ======== InterruptDsp.xs ========
34  */
36 var Hwi             = null;
37 var MultiProc       = null;
39 /*
40  *  ======== module$use ========
41  */
42 function module$use()
43 {
44     Hwi         = xdc.useModule("ti.sysbios.family.c64p.Hwi");
45     MultiProc   = xdc.useModule("ti.sdo.utils.MultiProc");
46     Ipc         = xdc.useModule("ti.sdo.ipc.Ipc");
48     this.dspProcId      = MultiProc.getIdMeta("DSP");
49     this.videoProcId    = MultiProc.getIdMeta("VIDEO-M3");
50     this.vpssProcId     = MultiProc.getIdMeta("VPSS-M3");
51     this.hostProcId     = MultiProc.getIdMeta("HOST");
52 }
54 function module$static$init(mod, params)
55 {
56     /* HOST to DSP */
57     mod.fxnTable[0].func  = null;
58     mod.fxnTable[0].arg   = 0;
60     /* VIDEO-M3 to DSP */
61     mod.fxnTable[1].func  = null;
62     mod.fxnTable[1].arg   = 0;
64     /* VPSS-M3 to DSP */
65     mod.fxnTable[2].func  = null;
66     mod.fxnTable[2].arg   = 0;
68     mod.numPlugged = 0;
69 }
71 /*
72  *  ======== viewInitInterrupt ========
73  */
74 function viewInitInterrupt(view)
75 {
76     var InterruptDspModStr = "ti.sdo.ipc.family.ti81xx.InterruptDsp";
77     var Program             = xdc.useModule('xdc.rov.Program');
78     var InterruptDsp       = xdc.useModule(InterruptDspModStr);
79     var MultiProc           = xdc.useModule('ti.sdo.utils.MultiProc');
80     var MultiProcCfg        = Program.getModuleConfig('ti.sdo.utils.MultiProc');
81     var InterruptDspCfg    = Program.getModuleConfig(InterruptDspModStr);
82     var ScalarStructs       = xdc.useModule('xdc.rov.support.ScalarStructs');
83     var mod                 = Program.scanRawView(InterruptDspModStr).modState;
85     var remoteProcIds = [
86         /*
87          * [remoteProcId,
88          *  fxnTable index,
89          *  MBX# (from remote),
90          *  MBX# (to remote)]
91          */
92         [InterruptDspCfg.hostProcId, 0, 3, 0],
93         [InterruptDspCfg.videoProcId, 1, 7, 1],
94         [InterruptDspCfg.vpssProcId, 2, 9, 2]
95     ];
97     var MAILBOX_IRQSTATUS_CLR_DSP = (InterruptDspCfg.mailboxBaseAddr + 0x114);
98     var MAILBOX_IRQENABLE_SET_DSP = (InterruptDspCfg.mailboxBaseAddr + 0x118);
99     var MAILBOX_IRQENABLE_CLR_DSP = (InterruptDspCfg.mailboxBaseAddr + 0x11C);
101     function MAILBOX_MESSAGE(M) {
102         return (InterruptDspCfg.mailboxBaseAddr + 0x040 + (0x4 * M));
103     }
105     function MAILBOX_STATUS(M) {
106         return (InterruptDspCfg.mailboxBaseAddr + 0x0C0 + (0x4 * M));
107     }
109     function MAILBOX_REG_VAL(M) {
110         return (0x1 << (2 * M));
111     }
113     for each (procId in remoteProcIds) {
114         if (procId[0] != MultiProc.INVALIDID) {
115             var entryView = Program.newViewStruct(InterruptDspModStr,
116                     'IncomingInterrupts');
117             entryView.remoteProcName = MultiProc.getName$view(procId[0]) + " ("
118                     + procId[0] + ")";
119             entryView.registered = (Number(mod.fxnTable[procId[1]].func) != 0);
120             print(entryView.remoteProcName + ": " + mod.fxnTable[procId[1]].func);
122             var enabled = Program.fetchStruct(
123                     ScalarStructs.S_Bits32$fetchDesc,
124                     $addr(MAILBOX_IRQENABLE_SET_DSP), false).elem;
125             entryView.enabled = ((enabled & MAILBOX_REG_VAL(procId[2])) != 0);
127             var intPending = Program.fetchStruct(
128                     ScalarStructs.S_Bits32$fetchDesc,
129                     $addr(MAILBOX_STATUS(procId[2])), false).elem;
130             entryView.intPending = (intPending != 0);
132             entryView.payload = $addr(Program.fetchStruct(
133                     ScalarStructs.S_Bits32$fetchDesc,
134                     $addr(MAILBOX_MESSAGE(procId[2])), false).elem);
136             view.elements.$add(entryView);
137         }
138     }