flow.h 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. /* SPDX-License-Identifier: GPL-2.0+ */
  2. /*
  3. * (C) Copyright 2010-2013
  4. * NVIDIA Corporation <www.nvidia.com>
  5. */
  6. #ifndef _TEGRA124_FLOW_H_
  7. #define _TEGRA124_FLOW_H_
  8. struct flow_ctlr {
  9. u32 halt_cpu_events; /* offset 0x00 */
  10. u32 halt_cop_events; /* offset 0x04 */
  11. u32 cpu_csr; /* offset 0x08 */
  12. u32 cop_csr; /* offset 0x0c */
  13. u32 xrq_events; /* offset 0x10 */
  14. u32 halt_cpu1_events; /* offset 0x14 */
  15. u32 cpu1_csr; /* offset 0x18 */
  16. u32 halt_cpu2_events; /* offset 0x1c */
  17. u32 cpu2_csr; /* offset 0x20 */
  18. u32 halt_cpu3_events; /* offset 0x24 */
  19. u32 cpu3_csr; /* offset 0x28 */
  20. u32 cluster_control; /* offset 0x2c */
  21. u32 halt_cop1_events; /* offset 0x30 */
  22. u32 halt_cop1_csr; /* offset 0x34 */
  23. u32 cpu_pwr_csr; /* offset 0x38 */
  24. u32 mpid; /* offset 0x3c */
  25. u32 ram_repair; /* offset 0x40 */
  26. u32 flow_dbg_sel; /* offset 0x44 */
  27. u32 flow_dbg_cnt0; /* offset 0x48 */
  28. u32 flow_dbg_cnt1; /* offset 0x4c */
  29. u32 flow_dbg_qual; /* offset 0x50 */
  30. u32 flow_ctlr_spare; /* offset 0x54 */
  31. u32 ram_repair_cluster1;/* offset 0x58 */
  32. };
  33. /* HALT_COP_EVENTS_0, 0x04 */
  34. #define EVENT_MSEC (1 << 24)
  35. #define EVENT_USEC (1 << 25)
  36. #define EVENT_JTAG (1 << 28)
  37. #define EVENT_MODE_STOP (2 << 29)
  38. /* FLOW_CTLR_CLUSTER_CONTROL_0 0x2c */
  39. #define ACTIVE_LP (1 << 0)
  40. /* CPUn_CSR_0 */
  41. #define CSR_ENABLE (1 << 0)
  42. #define CSR_IMMEDIATE_WAKE (1 << 3)
  43. #define CSR_WAIT_WFI_SHIFT 8
  44. #define CSR_PWR_OFF_STS (1 << 16)
  45. /* RAM_REPAIR, 0x40, 0x58 */
  46. enum {
  47. RAM_REPAIR_REQ = 0x1 << 0,
  48. RAM_REPAIR_STS = 0x1 << 1,
  49. };
  50. #endif /* _TEGRA124_FLOW_H_ */