2018-05-06 21:58:06 +00:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0+ */
|
2016-07-20 09:55:12 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2016 Atmel Corporation
|
|
|
|
* Wenyou.Yang <wenyou.yang@atmel.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __AT91_PMC_H__
|
|
|
|
#define __AT91_PMC_H__
|
|
|
|
|
2020-09-07 14:46:38 +00:00
|
|
|
#include <linux/bitops.h>
|
|
|
|
#include <linux/io.h>
|
|
|
|
|
|
|
|
/* Keep a range of 256 available clocks for every clock type. */
|
|
|
|
#define AT91_TO_CLK_ID(_t, _i) (((_t) << 8) | ((_i) & 0xff))
|
|
|
|
#define AT91_CLK_ID_TO_DID(_i) ((_i) & 0xff)
|
2017-09-05 10:30:07 +00:00
|
|
|
|
2020-09-07 14:46:38 +00:00
|
|
|
int at91_clk_mux_val_to_index(const u32 *table, u32 num_parents, u32 val);
|
|
|
|
int at91_clk_mux_index_to_val(const u32 *table, u32 num_parents, u32 index);
|
|
|
|
|
|
|
|
void pmc_read(void __iomem *base, unsigned int off, unsigned int *val);
|
|
|
|
void pmc_write(void __iomem *base, unsigned int off, unsigned int val);
|
|
|
|
void pmc_update_bits(void __iomem *base, unsigned int off, unsigned int mask,
|
|
|
|
unsigned int bits);
|
2020-09-07 14:46:39 +00:00
|
|
|
|
2016-07-20 09:55:12 +00:00
|
|
|
#endif
|