zephyr/drivers/clock_control/clock_control_renesas_cpg_mssr.c
Aymeric Aillet 9a7040303a drivers: clock: rcar: Rename global includes file
Rename r-car clock driver global include file
in order to match other files names.

Signed-off-by: Aymeric Aillet <aymeric.aillet@iot.bzh>
2022-06-28 18:11:44 +02:00

51 lines
1.2 KiB
C

/*
* Copyright (c) 2020-2022 IoT.bzh
*
* SPDX-License-Identifier: Apache-2.0
*/
#include <zephyr/drivers/clock_control.h>
#include <zephyr/drivers/clock_control/renesas_cpg_mssr.h>
#include <zephyr/dt-bindings/clock/renesas_cpg_mssr.h>
#include "clock_control_renesas_cpg_mssr.h"
static void rcar_cpg_reset(uint32_t base_address, uint32_t reg, uint32_t bit)
{
rcar_cpg_write(base_address, srcr[reg], BIT(bit));
rcar_cpg_write(base_address, SRSTCLR(reg), BIT(bit));
}
void rcar_cpg_write(uint32_t base_address, uint32_t reg, uint32_t val)
{
sys_write32(~val, base_address + CPGWPR);
sys_write32(val, base_address + reg);
/* Wait for at least one cycle of the RCLK clock (@ ca. 32 kHz) */
k_sleep(K_USEC(35));
}
int rcar_cpg_mstp_clock_endisable(uint32_t base_address, uint32_t bit,
uint32_t reg, bool enable)
{
uint32_t bitmask = BIT(bit);
uint32_t reg_val;
unsigned int key;
key = irq_lock();
reg_val = sys_read32(base_address + mstpcr[reg]);
if (enable) {
reg_val &= ~bitmask;
} else {
reg_val |= bitmask;
}
sys_write32(reg_val, base_address + mstpcr[reg]);
if (!enable) {
rcar_cpg_reset(base_address, reg, bit);
}
irq_unlock(key);
return 0;
}