123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163 |
- /*
- * exynos_ppmu.h - EXYNOS PPMU header file
- *
- * Copyright (c) 2015 Samsung Electronics Co., Ltd.
- * Author : Chanwoo Choi <cw00.choi@samsung.com>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 2 as
- * published by the Free Software Foundation.
- */
- #ifndef __EXYNOS_PPMU_H__
- #define __EXYNOS_PPMU_H__
- enum ppmu_state {
- PPMU_DISABLE = 0,
- PPMU_ENABLE,
- };
- enum ppmu_counter {
- PPMU_PMNCNT0 = 0,
- PPMU_PMNCNT1,
- PPMU_PMNCNT2,
- PPMU_PMNCNT3,
- PPMU_PMNCNT_MAX,
- };
- /***
- * PPMUv1.1 Definitions
- */
- enum ppmu_event_type {
- PPMU_RO_BUSY_CYCLE_CNT = 0x0,
- PPMU_WO_BUSY_CYCLE_CNT = 0x1,
- PPMU_RW_BUSY_CYCLE_CNT = 0x2,
- PPMU_RO_REQUEST_CNT = 0x3,
- PPMU_WO_REQUEST_CNT = 0x4,
- PPMU_RO_DATA_CNT = 0x5,
- PPMU_WO_DATA_CNT = 0x6,
- PPMU_RO_LATENCY = 0x12,
- PPMU_WO_LATENCY = 0x16,
- };
- enum ppmu_reg {
- /* PPC control register */
- PPMU_PMNC = 0x00,
- PPMU_CNTENS = 0x10,
- PPMU_CNTENC = 0x20,
- PPMU_INTENS = 0x30,
- PPMU_INTENC = 0x40,
- PPMU_FLAG = 0x50,
- /* Cycle Counter and Performance Event Counter Register */
- PPMU_CCNT = 0x100,
- PPMU_PMCNT0 = 0x110,
- PPMU_PMCNT1 = 0x120,
- PPMU_PMCNT2 = 0x130,
- PPMU_PMCNT3_HIGH = 0x140,
- PPMU_PMCNT3_LOW = 0x150,
- /* Bus Event Generator */
- PPMU_BEVT0SEL = 0x1000,
- PPMU_BEVT1SEL = 0x1100,
- PPMU_BEVT2SEL = 0x1200,
- PPMU_BEVT3SEL = 0x1300,
- PPMU_COUNTER_RESET = 0x1810,
- PPMU_READ_OVERFLOW_CNT = 0x1810,
- PPMU_READ_UNDERFLOW_CNT = 0x1814,
- PPMU_WRITE_OVERFLOW_CNT = 0x1850,
- PPMU_WRITE_UNDERFLOW_CNT = 0x1854,
- PPMU_READ_PENDING_CNT = 0x1880,
- PPMU_WRITE_PENDING_CNT = 0x1884
- };
- /* PMNC register */
- #define PPMU_PMNC_CC_RESET_SHIFT 2
- #define PPMU_PMNC_COUNTER_RESET_SHIFT 1
- #define PPMU_PMNC_ENABLE_SHIFT 0
- #define PPMU_PMNC_START_MODE_MASK BIT(16)
- #define PPMU_PMNC_CC_DIVIDER_MASK BIT(3)
- #define PPMU_PMNC_CC_RESET_MASK BIT(2)
- #define PPMU_PMNC_COUNTER_RESET_MASK BIT(1)
- #define PPMU_PMNC_ENABLE_MASK BIT(0)
- /* CNTENS/CNTENC/INTENS/INTENC/FLAG register */
- #define PPMU_CCNT_MASK BIT(31)
- #define PPMU_PMCNT3_MASK BIT(3)
- #define PPMU_PMCNT2_MASK BIT(2)
- #define PPMU_PMCNT1_MASK BIT(1)
- #define PPMU_PMCNT0_MASK BIT(0)
- /* PPMU_PMNCTx/PPMU_BETxSEL registers */
- #define PPMU_PMNCT(x) (PPMU_PMCNT0 + (0x10 * x))
- #define PPMU_BEVTxSEL(x) (PPMU_BEVT0SEL + (0x100 * x))
- /***
- * PPMU_V2.0 definitions
- */
- enum ppmu_v2_mode {
- PPMU_V2_MODE_MANUAL = 0,
- PPMU_V2_MODE_AUTO = 1,
- PPMU_V2_MODE_CIG = 2, /* CIG (Conditional Interrupt Generation) */
- };
- enum ppmu_v2_event_type {
- PPMU_V2_RO_DATA_CNT = 0x4,
- PPMU_V2_WO_DATA_CNT = 0x5,
- PPMU_V2_EVT3_RW_DATA_CNT = 0x22, /* Only for Event3 */
- };
- enum ppmu_V2_reg {
- /* PPC control register */
- PPMU_V2_PMNC = 0x04,
- PPMU_V2_CNTENS = 0x08,
- PPMU_V2_CNTENC = 0x0c,
- PPMU_V2_INTENS = 0x10,
- PPMU_V2_INTENC = 0x14,
- PPMU_V2_FLAG = 0x18,
- /* Cycle Counter and Performance Event Counter Register */
- PPMU_V2_CCNT = 0x48,
- PPMU_V2_PMCNT0 = 0x34,
- PPMU_V2_PMCNT1 = 0x38,
- PPMU_V2_PMCNT2 = 0x3c,
- PPMU_V2_PMCNT3_LOW = 0x40,
- PPMU_V2_PMCNT3_HIGH = 0x44,
- /* Bus Event Generator */
- PPMU_V2_CIG_CFG0 = 0x1c,
- PPMU_V2_CIG_CFG1 = 0x20,
- PPMU_V2_CIG_CFG2 = 0x24,
- PPMU_V2_CIG_RESULT = 0x28,
- PPMU_V2_CNT_RESET = 0x2c,
- PPMU_V2_CNT_AUTO = 0x30,
- PPMU_V2_CH_EV0_TYPE = 0x200,
- PPMU_V2_CH_EV1_TYPE = 0x204,
- PPMU_V2_CH_EV2_TYPE = 0x208,
- PPMU_V2_CH_EV3_TYPE = 0x20c,
- PPMU_V2_SM_ID_V = 0x220,
- PPMU_V2_SM_ID_A = 0x224,
- PPMU_V2_SM_OTHERS_V = 0x228,
- PPMU_V2_SM_OTHERS_A = 0x22c,
- PPMU_V2_INTERRUPT_RESET = 0x260,
- };
- /* PMNC register */
- #define PPMU_V2_PMNC_START_MODE_SHIFT 20
- #define PPMU_V2_PMNC_START_MODE_MASK (0x3 << PPMU_V2_PMNC_START_MODE_SHIFT)
- #define PPMU_PMNC_CC_RESET_SHIFT 2
- #define PPMU_PMNC_COUNTER_RESET_SHIFT 1
- #define PPMU_PMNC_ENABLE_SHIFT 0
- #define PPMU_PMNC_START_MODE_MASK BIT(16)
- #define PPMU_PMNC_CC_DIVIDER_MASK BIT(3)
- #define PPMU_PMNC_CC_RESET_MASK BIT(2)
- #define PPMU_PMNC_COUNTER_RESET_MASK BIT(1)
- #define PPMU_PMNC_ENABLE_MASK BIT(0)
- #define PPMU_V2_PMNCT(x) (PPMU_V2_PMCNT0 + (0x4 * x))
- #define PPMU_V2_CH_EVx_TYPE(x) (PPMU_V2_CH_EV0_TYPE + (0x4 * x))
- #endif /* __EXYNOS_PPMU_H__ */
|