1 /*
2 * Copyright (c) 2019-2025 Allwinner Technology Co., Ltd. ALL rights reserved.
3 *
4 * Allwinner is a trademark of Allwinner Technology Co.,Ltd., registered in
5 * the the People's Republic of China and other countries.
6 * All Allwinner Technology Co.,Ltd. trademarks are used with permission.
7 *
8 * DISCLAIMER
9 * THIRD PARTY LICENCES MAY BE REQUIRED TO IMPLEMENT THE SOLUTION/PRODUCT.
10 * IF YOU NEED TO INTEGRATE THIRD PARTY'S TECHNOLOGY (SONY, DTS, DOLBY, AVS OR MPEGLA, ETC.)
11 * IN ALLWINNERS'SDK OR PRODUCTS, YOU SHALL BE SOLELY RESPONSIBLE TO OBTAIN
12 * ALL APPROPRIATELY REQUIRED THIRD PARTY LICENCES.
13 * ALLWINNER SHALL HAVE NO WARRANTY, INDEMNITY OR OTHER OBLIGATIONS WITH RESPECT TO MATTERS
14 * COVERED UNDER ANY REQUIRED THIRD PARTY LICENSE.
15 * YOU ARE SOLELY RESPONSIBLE FOR YOUR USAGE OF THIRD PARTY'S TECHNOLOGY.
16 *
17 *
18 * THIS SOFTWARE IS PROVIDED BY ALLWINNER"AS IS" AND TO THE MAXIMUM EXTENT
19 * PERMITTED BY LAW, ALLWINNER EXPRESSLY DISCLAIMS ALL WARRANTIES OF ANY KIND,
20 * WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING WITHOUT LIMITATION REGARDING
21 * THE TITLE, NON-INFRINGEMENT, ACCURACY, CONDITION, COMPLETENESS, PERFORMANCE
22 * OR MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
23 * IN NO EVENT SHALL ALLWINNER BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
25 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
26 * LOSS OF USE, DATA, OR PROFITS, OR BUSINESS INTERRUPTION)
27 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
28 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
29 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
30 * OF THE POSSIBILITY OF SUCH DAMAGE.
31 */
32 
33 #ifndef __MSGBOX_SUN50IW11_H__
34 #define __MSGBOX_SUN50IW11_H__
35 
36 /* config for DSP */
37 #if defined(CONFIG_CORE_DSP0)
38 #include <interrupt.h>
39 #include <hal_prcm.h>
40 
41 #define MSGBOX0_CPU_DSP0    0x03003000
42 #define MSGBOX1_CPU_DSP1    0x03008000
43 #define MSGBOXR_DSP0_DSP1   0x07092000
44 
45 #if defined(CONFIG_CORE_DSP0)   /* DSP0 */
46 #define MSGBOX_CPU_DSP      MSGBOX0_CPU_DSP0
47 #define MSGBOX_DSP_DSP      MSGBOXR_DSP0_DSP1
48 
49 #define MSGBOX_CPU_DSP_USER (1)
50 #define MSGBOX_DSP_DSP_USER (0)
51 
52 #elif defined(CONFIG_CORE_DSP1) /* DSP1 */
53 #define MSGBOX_CPU_DSP      MSGBOX1_CPU_DSP1
54 #define MSGBOX_DSP_DSP      MSGBOXR_DSP0_DSP1
55 
56 #define MSGBOX_CPU_DSP_USER (1)
57 #define MSGBOX_DSP_DSP_USER (1)
58 
59 #else               /* error */
60 #error "must select dsp core"
61 #endif
62 
63 /* for prcm and ccmu compatibility */
64 #define HAL_CLK_PERIPH_MSGBOX0  CCU_MOD_CLK_MSGBOX0
65 #define HAL_CLK_PERIPH_MSGBOX1  CCU_MOD_CLK_MSGBOX1
66 #define HAL_CLK_PERIPH_MSGBOXR  CCU_MOD_CLK_MSGBOXR
67 #endif /* CONFIG_CORE_DSP0 */
68 
69 #if defined(CONFIG_CORE_DSP0)
70 #define SUNXI_DSP_IRQ_R_MSGBOX_DSP  3
71 #define SUNXI_DSP_IRQ_MSGBOX0_DSP   4
72 #else
73 #define SUNXI_DSP_IRQ_R_MSGBOX_DSP  3
74 #define SUNXI_DSP_IRQ_MSGBOX0_DSP   4
75 #endif
76 
77 
78 #endif /*__MSGBOX_SUN50IW11_H__  */
79