blob: 4b020b969d9bd560dfc61c15b06c6b002a850d1f [file] [log] [blame]
rjw6c1fd8f2022-11-30 14:33:01 +08001/*****************************************************************************
2* Copyright Statement:
3* --------------------
4* This software is protected by Copyright and the information contained
5* herein is confidential. The software may not be copied and the information
6* contained herein may not be used or disclosed except with the written
7* permission of MediaTek Inc. (C) 2013
8*
9* BY OPENING THIS FILE, BUYER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
10* THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE")
11* RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO BUYER ON
12* AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES,
13* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF
14* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT.
15* NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE
16* SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR
17* SUPPLIED WITH THE MEDIATEK SOFTWARE, AND BUYER AGREES TO LOOK ONLY TO SUCH
18* THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. MEDIATEK SHALL ALSO
19* NOT BE RESPONSIBLE FOR ANY MEDIATEK SOFTWARE RELEASES MADE TO BUYER'S
20* SPECIFICATION OR TO CONFORM TO A PARTICULAR STANDARD OR OPEN FORUM.
21*
22* BUYER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND CUMULATIVE
23* LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE,
24* AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE,
25* OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY BUYER TO
26* MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE.
27*
28* THE TRANSACTION CONTEMPLATED HEREUNDER SHALL BE CONSTRUED IN ACCORDANCE
29* WITH THE LAWS OF THE STATE OF CALIFORNIA, USA, EXCLUDING ITS CONFLICT OF
30* LAWS PRINCIPLES. ANY DISPUTES, CONTROVERSIES OR CLAIMS ARISING THEREOF AND
31* RELATED THERETO SHALL BE SETTLED BY ARBITRATION IN SAN FRANCISCO, CA, UNDER
32* THE RULES OF THE INTERNATIONAL CHAMBER OF COMMERCE (ICC).
33*
34*****************************************************************************/
35
36/*******************************************************************************
37 * Filename:
38 * ---------
39 * simctrl.h
40 *
41 * Project:
42 * --------
43 * MOLY
44 *
45 * Description:
46 * ------------
47 * Driver header of LTE L1 ESL Simulation Controller
48 *
49 * Author:
50 * -------
51 * -------
52 *
53 * ==========================================================================
54 * $Log$
55 ****************************************************************************/
56#ifndef __SIMCTRL_H__
57#define __SIMCTRL_H__
58
59#include <reg_base.h>
60
61#define SIMCTRL_STOP_SIMULATION_REG (BASE_ADDR_SIMCTRL + 0x00)
62#define SIMCTRL_STOP_PARAMETER0_REG (BASE_ADDR_SIMCTRL + 0x04)
63#define SIMCTRL_STOP_PARAMETER1_REG (BASE_ADDR_SIMCTRL + 0x08)
64#define SIMCTRL_STOP_PARAMETER2_REG (BASE_ADDR_SIMCTRL + 0x0C)
65
66#define SIMCTRL_TESTCASENAME_CHAR_REG (BASE_ADDR_SIMCTRL + 0x10)
67#define SIMCTRL_TEST_CASE_START_REG (BASE_ADDR_SIMCTRL + 0x14)
68#define SIMCTRL_AXI_LOGGING_START_REG (BASE_ADDR_SIMCTRL + 0x18)
69
70#define SIMCTRL_TASKNAME_CHAR_REG (BASE_ADDR_SIMCTRL + 0x20)
71#define SIMCTRL_OUTPUTLOG_REG (BASE_ADDR_SIMCTRL + 0x24)
72#define SIMCTRL_CYCLECOUNT_REG (BASE_ADDR_SIMCTRL + 0x28)
73#define SIMCTRL_INSTRCOUNT_REG (BASE_ADDR_SIMCTRL + 0x2C)
74#define SIMCTRL_ICMISSCOUNT_REG (BASE_ADDR_SIMCTRL + 0x30)
75#define SIMCTRL_DCMISSCOUNT_REG (BASE_ADDR_SIMCTRL + 0x34)
76
77#define SIMCTRL_SIMULATION_DONE (0x02 << 28)
78#define SIMCTRL_AXI_LOGGING_START (1)
79#define SIMCTRL_AXI_LOGGING_STOP (0)
80#define SIMCTRL_TESTCASE_START (1)
81#define SIMCTRL_TESTCASE_STOP (0)
82
83#define M_SIMCTRL_STOP_SIMULATION(cAUSE) (*((volatile unsigned long int *) (SIMCTRL_STOP_SIMULATION_REG))) = (cAUSE)
84#define M_SIMCTRL_SET_CYCLE_COUNT(cOUNT) (*((volatile unsigned long int *) (SIMCTRL_CYCLECOUNT_REG))) = (cOUNT)
85#define M_SIMCTRL_SET_INSTR_COUNT(cOUNT) (*((volatile unsigned long int *) (SIMCTRL_INSTRCOUNT_REG))) = (cOUNT)
86#define M_SIMCTRL_SET_ICMISS_COUNT(cOUNT) (*((volatile unsigned long int *) (SIMCTRL_ICMISSCOUNT_REG))) = (cOUNT)
87#define M_SIMCTRL_SET_DCMISS_COUNT(cOUNT) (*((volatile unsigned long int *) (SIMCTRL_DCMISSCOUNT_REG))) = (cOUNT)
88#define M_SIMCTRL_OUTPUT_TASK_LOG() (*((volatile unsigned long int *) (SIMCTRL_OUTPUTLOG_REG))) = (1)
89#define M_SIMCTRL_SET_AXI_LOGGING(sTART) (*((volatile unsigned long int *) (SIMCTRL_AXI_LOGGING_START_REG))) = (sTART)
90#define M_SIMCTRL_APPEND_TASKNAME(c) (*((volatile unsigned long int *) (SIMCTRL_TASKNAME_CHAR_REG))) = (c)
91#define M_SIMCTRL_APPEND_TESTCASENAME(c) (*((volatile unsigned long int *) (SIMCTRL_TESTCASENAME_CHAR_REG))) = (c)
92#define M_SIMCTRL_SET_TESTCASE_START(sTART) (*((volatile unsigned long int *) (SIMCTRL_TEST_CASE_START_REG))) = (sTART)
93
94#endif