/* * Copyright (c) 2012 Samsung Electronics Co., Ltd. * http://www.samsung.com/ * * EXYNOS - PPMU support * * 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. */ #include <linux/kernel.h> #include <linux/types.h> #include <linux/io.h> #include "exynos_ppmu.h" void exynos_ppmu_reset(void __iomem *ppmu_base) { __raw_writel(PPMU_CYCLE_RESET | PPMU_COUNTER_RESET, ppmu_base); __raw_writel(PPMU_ENABLE_CYCLE | PPMU_ENABLE_COUNT0 | PPMU_ENABLE_COUNT1 | PPMU_ENABLE_COUNT2 | PPMU_ENABLE_COUNT3, ppmu_base + PPMU_CNTENS); } void exynos_ppmu_setevent(void __iomem *ppmu_base, unsigned int ch, unsigned int evt) { __raw_writel(evt, ppmu_base + PPMU_BEVTSEL(ch)); } void exynos_ppmu_start(void __iomem *ppmu_base) { __raw_writel(PPMU_ENABLE, ppmu_base); } void exynos_ppmu_stop(void __iomem *ppmu_base) { __raw_writel(PPMU_DISABLE, ppmu_base); } unsigned int exynos_ppmu_read(void __iomem *ppmu_base, unsigned int ch) { unsigned int total; if (ch == PPMU_PMNCNT3) total = ((__raw_readl(ppmu_base + PMCNT_OFFSET(ch)) << 8) | __raw_readl(ppmu_base + PMCNT_OFFSET(ch + 1))); else total = __raw_readl(ppmu_base + PMCNT_OFFSET(ch)); return total; }