2013-10-10 08:45:07 +02:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2010-2013, NVIDIA CORPORATION. All rights reserved.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms and conditions of the GNU General Public License,
|
|
|
|
* version 2, as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
|
|
* more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _TEGRA124_FLOW_H_
|
|
|
|
#define _TEGRA124_FLOW_H_
|
|
|
|
|
|
|
|
struct flow_ctlr {
|
|
|
|
u32 halt_cpu_events; /* offset 0x00 */
|
|
|
|
u32 halt_cop_events; /* offset 0x04 */
|
|
|
|
u32 cpu_csr; /* offset 0x08 */
|
|
|
|
u32 cop_csr; /* offset 0x0c */
|
|
|
|
u32 xrq_events; /* offset 0x10 */
|
|
|
|
u32 halt_cpu1_events; /* offset 0x14 */
|
|
|
|
u32 cpu1_csr; /* offset 0x18 */
|
|
|
|
u32 halt_cpu2_events; /* offset 0x1c */
|
|
|
|
u32 cpu2_csr; /* offset 0x20 */
|
|
|
|
u32 halt_cpu3_events; /* offset 0x24 */
|
|
|
|
u32 cpu3_csr; /* offset 0x28 */
|
|
|
|
u32 cluster_control; /* offset 0x2c */
|
|
|
|
u32 halt_cop1_events; /* offset 0x30 */
|
|
|
|
u32 halt_cop1_csr; /* offset 0x34 */
|
|
|
|
u32 cpu_pwr_csr; /* offset 0x38 */
|
|
|
|
u32 mpid; /* offset 0x3c */
|
|
|
|
u32 ram_repair; /* offset 0x40 */
|
|
|
|
};
|
2013-12-10 02:46:22 +01:00
|
|
|
check_member(flow_ctlr, ram_repair, 0x40);
|
2013-10-10 08:45:07 +02:00
|
|
|
|
2013-10-26 02:49:26 +02:00
|
|
|
enum {
|
|
|
|
FLOW_MODE_SHIFT = 29,
|
|
|
|
FLOW_MODE_MASK = 0x7 << FLOW_MODE_SHIFT,
|
|
|
|
|
|
|
|
FLOW_MODE_NONE = 0 << FLOW_MODE_SHIFT,
|
|
|
|
FLOW_MODE_RUN_AND_INT = 1 << FLOW_MODE_SHIFT,
|
|
|
|
FLOW_MODE_WAITEVENT = 2 << FLOW_MODE_SHIFT,
|
|
|
|
FLOW_MODE_WAITEVENT_AND_INT = 3 << FLOW_MODE_SHIFT,
|
|
|
|
FLOW_MODE_STOP_UNTIL_IRQ = 4 << FLOW_MODE_SHIFT,
|
|
|
|
FLOW_MODE_STOP_UNTIL_IRQ_AND_INT = 5 << FLOW_MODE_SHIFT,
|
|
|
|
FLOW_MODE_STOP_UNTIL_EVENT_AND_IRQ = 6 << FLOW_MODE_SHIFT,
|
|
|
|
};
|
2013-10-10 08:45:07 +02:00
|
|
|
|
2013-10-26 02:49:26 +02:00
|
|
|
/* HALT_COP_EVENTS_0, 0x04 */
|
|
|
|
enum {
|
|
|
|
FLOW_EVENT_GIC_FIQ = 1 << 8,
|
|
|
|
FLOW_EVENT_GIC_IRQ = 1 << 9,
|
|
|
|
FLOW_EVENT_LIC_FIQ = 1 << 10,
|
|
|
|
FLOW_EVENT_LIC_IRQ = 1 << 11,
|
|
|
|
FLOW_EVENT_IBF = 1 << 12,
|
|
|
|
FLOW_EVENT_IBE = 1 << 13,
|
|
|
|
FLOW_EVENT_OBF = 1 << 14,
|
|
|
|
FLOW_EVENT_OBE = 1 << 15,
|
|
|
|
FLOW_EVENT_XRQ_A = 1 << 16,
|
|
|
|
FLOW_EVENT_XRQ_B = 1 << 17,
|
|
|
|
FLOW_EVENT_XRQ_C = 1 << 18,
|
|
|
|
FLOW_EVENT_XRQ_D = 1 << 19,
|
|
|
|
FLOW_EVENT_SMP30 = 1 << 20,
|
|
|
|
FLOW_EVENT_SMP31 = 1 << 21,
|
|
|
|
FLOW_EVENT_X_RDY = 1 << 22,
|
|
|
|
FLOW_EVENT_SEC = 1 << 23,
|
|
|
|
FLOW_EVENT_MSEC = 1 << 24,
|
|
|
|
FLOW_EVENT_USEC = 1 << 25,
|
|
|
|
FLOW_EVENT_X32K = 1 << 26,
|
|
|
|
FLOW_EVENT_SCLK = 1 << 27,
|
|
|
|
FLOW_EVENT_JTAG = 1 << 28
|
|
|
|
};
|
2013-10-10 08:45:07 +02:00
|
|
|
|
|
|
|
#endif /* _TEGRA124_FLOW_H_ */
|