2 * Copyright (C) 2015 Atmel Corporation
3 * Wenyou Yang <wenyou.yang@atmel.com>
5 * SPDX-License-Identifier: GPL-2.0+
10 #include <asm/arch/hardware.h>
11 #include <asm/arch/at91_pmc.h>
13 void at91_periph_clk_enable(int id)
15 struct at91_pmc *pmc = (struct at91_pmc *)ATMEL_BASE_PMC;
21 if (id > AT91_PMC_PCR_PID_MASK)
24 writel(id, &pmc->pcr);
26 div_value = readl(&pmc->pcr) & AT91_PMC_PCR_DIV;
28 regval = AT91_PMC_PCR_EN | AT91_PMC_PCR_CMD_WRITE | id | div_value;
30 writel(regval, &pmc->pcr);
32 writel(0x01 << id, &pmc->pcer);
36 void at91_periph_clk_disable(int id)
38 struct at91_pmc *pmc = (struct at91_pmc *)ATMEL_BASE_PMC;
43 if (id > AT91_PMC_PCR_PID_MASK)
46 regval = AT91_PMC_PCR_CMD_WRITE | id;
48 writel(regval, &pmc->pcr);
50 writel(0x01 << id, &pmc->pcdr);
54 void at91_system_clk_enable(int sys_clk)
56 struct at91_pmc *pmc = (struct at91_pmc *)ATMEL_BASE_PMC;
58 writel(sys_clk, &pmc->scer);
61 void at91_system_clk_disable(int sys_clk)
63 struct at91_pmc *pmc = (struct at91_pmc *)ATMEL_BASE_PMC;
65 writel(sys_clk, &pmc->scdr);